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A GATED STORE BUFFER FOR AN ADVANCED MICROPROCESSOR 



BACKGROUND OF THE INVENTION 
Field Of The Invention 

5 This invention relates to computer systems and, more particularly, to a gated 
store buffer utilized for controlling memory stores with a host microprocessor 
which executes programs translated from programs designed for execution by 
a different processor. 

History Of The Prior Art 

JO There are thousands of application programs which run on computers 

designed around particular families of microprocessors. The largest number of 
programs in existence are designed to run on computers (generally referred to 
as "IBM Compatible Personal Computers") using the family of 

microprocessors (including the Intel® 8088, Intel 8086, Intel 80186, Intel 

15 80286, i386, i486, and progressing through the various Pentium® 

microprocessors) designed and manufactured by Intel Corporation of Santa 
Clara, California. There are many other examples of programs designed to run 
on computers using other families of processors. Because there are so many 
application programs which run on these computers, there is a large market 

20 for microprocessors capable of use in such computers, especially computers 
designed to process X86 programs. The microprocessor market is not only 
large but also quite lucrative. 

Although the market for microprocessors which are able to run large numbers 
of application programs is large and lucrative, it is quite difficult to design a 
25 new competitive microprocessor. For example, even though the X86 family of 
processors has been in existence for a number of years and these processors 
are included in the majority of computers sold and used, there are few 
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successful competitive microprocessors which are able to run X86 programs. 
The reasons for this are many. 

In order to be successful, a microprocessor must be able to run all of the 
programs (including operating systems and legacy programs) designed for that 
family of processors as fast as existing processors without costing more than 
existing processors. In addition, to be economically successful, a new 
microprocessor must do at least one of these things better than existing 
processors to give buyers a reason to choose the new processor over existing 
proven processors. 

It is difficult and expensive to make a microprocessor run as fast as state of 
the art microprocessors. Processors carry out instructions through primitive 
operations such as loading, shifting, adding, storing, and similar low level 
operations and respond only to such primitive instructions in executing any 
instruction fumished by an application program. For example, a processor 
designed to run the instructions of a complicated instruction set computer 
(CISC) such as a X86 in which instructions may designate the process to be 
carried out at a relatively high level have historically included read only 
memory (ROM) which stores so-called micro-instructions. Each micro- 
instruction includes a sequence of primitive instructions which when run in 
succession bring about the result commanded by the high level CISC 
instruction. Typically, an "add A to B" CISC instruction is decoded to cause a 
look up of an address in ROM at which a micro-instruction for carrying out the 
functions of the "add A to B" instruction is stored. The micro-instruction is 
loaded, and its primitive instructions are run in sequence to cause the "add A 
to B" instruction to be carried out. With such a CISC computer, the primitive 
operations within a micro-instruction can never be changed during program 
execution. Each CISC instruction can only be run by decoding the instruction, 
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addressing and fetching the micro-instruction, and running the sequence of 
primitive operations in the order provided in the micro-instruction. Each time 
the micro-instruction is run, the same sequence must be followed. 

State of the art processors for running X86 applications utilize a number of 
techniques to provide the fastest processing possible at a price which is still 
economically reasonable. Any new processor which implements known 
hardware techniques for accelerating the speed at which a processor may run 
must increase the sophistication of the processing hardware. This requires 
increasing the cost of the hardware. 

For example, a superscalar microprocessor which uses a plurality of 
processing channels in order to execute two or more operations at once has a 
number of additional requirements. At the most basic level, a simple 
superscalar microprocessor might decode each application instruction into the 
micro-instructions which carry out the function of the application instruction. 
Then, the simple superscalar microprocessor schedules two micro-instructions 
to run together if the two micro-instructions do not require the same hardware 
resources and the execution of a micro-instruction does not depend on the 
results of other micro-instructions being processed. 

A more advanced superscalar microprocessor typically decodes each 
application instruction into a series of primitive instructions so that those 
primitive instructions may be reordered and scheduled into the most efficient 
execution order. This requires that each individual primitive operation be 
addressed and fetched. To accomplish reordering, the processor must be able 
to ensure that a primitive instruction which requires data resulting from 
another primitive instruction is run after that other primitive instruction 
produces the needed data. Such a superscalar microprocessor must assure 
that two primitive instructions being run together do not both require the same 
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hardware resources. Such a processor must also resolve conditional branches 
before the effects of branch operations can be completed. 

Thus, superscalar microprocessors require extensive hardware to compare the 
relationships of the primitive instructions to one another and to reorder and 
5 schedule the sequence of the primitive instructions to carry out any 

instruction. As the number of processing channels increases, the amount and 
cost of the hardware to accomplish these superscalar acceleration techniques 
increases approximately quadratically. All of these hardware requirements 
increase the complexity and cost of the circuitry involved. As in dealing with 

10 micro-instructions, each time an application instruction is executed, a 

superscalar microprocessor must use its relatively complicated addressing and 
fetching hardware to fetch each of these primitive instructions, must reorder 
and reschedule these primitive instructions based on the other primitive 
instructions and hardware usage, and then must execute all of the 

15 rescheduled primitive instructions. The need to run each application 

instruction through the entire hardware sequence each time it is executed 
limits the speed at which a superscalar processor is capable of executing its 
instructions. 

Moreover, even though these various hardware techniques increase the speed 
20 of processing, the complexity involved in providing such hardware significantly 
increases the cost of such a microprocessor. For example, the Intel i486 DX4 
processor uses approximately 1.5 million transistors. Adding the hardware 
required to accomplish the checking of dependencies and scheduling necessary 
to process instructions through two channels in a basic superscalar 
25 microprocessor such as the Intel Pentium® requires the use of more than three 
million transistors. Adding the hardware to allow reordering among primitive 
instructions derived from different target instructions, provide speculative 
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execution, allow register renaming, and provide branch prediction increases 
the number of transistors to over six million in the Intel Pentium Pro*^*^ 
microprocessor. Thus, it can be seen that each hardware addition to increase 
operation speed has drastically increased the number of transistors in the 
5 latest state of the art microprocessors. 

Even using these known techniques may not produce a microprocessor faster 
than existing microprocessors because manufacturers use most of the 
economically feasible techniques known to accelerate the operation of existing 
microprocessors, Consequentiy, designing a faster processor is a very difficult 
10 and expensive task. 

Reducing the cost of a processor is also very difficult. As illustrated above, 
hardware acceleration techniques which produce a sufficiently capable 
processor are very expensive. One designing a new processor must obtain the 
facilities to produce the hardware. Such facilities are very difficult to obtain 
15 because chip manufacturers do not typicsdly spend assets on small runs of 
devices. The capital investment required to produce a chip manufacturing 
facility is so great that it is beyond the reach of most companies. 

Even though one is able to design a new processor which runs all of the 
apphcation programs designed for a family of processors at least as fast as 
20 competitive processors, the price of competitive processors includes sufficient 
profit that substantial price reductions are sure to be faced by any competitor. 

Although designing a competitive processor by increasing the complexity of the 
hardware is very difficult, another way to run application programs (target 
application programs) designed for a particular family of microprocessors 
25 (target microprocessors) has been to emulate the target microprocessor in 
software on another faster microprocessor (host microprocessor). This is an 
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incrementally inexpensive method of running these programs because it 
requires only the addition of some form of emulation software which enables 
the application program to run on a faster microprocessor. The emulator 
software changes the target instructions of an application program written for 
5 the target processor family into host instructions capable of execution by the 
host microprocessor. These changed instructions are then run under control 
of the operating system on the faster host microprocessor. 

There have been a number of different designs by which target applications 
may be run on host computers with faster processors than the processors of 
10 target computers. In general, the host computers executing target programs 
using emulation software utilize reduced instruction set (RISC) 
microprocessors because RISC processors are theoretically simpler and 
consequently can run faster than other types of processors. 

However, even though RISC computer systems running emulator software are 
15 often capable of running X86 (or other) programs, they usually do so at a rate 
which is substantially slower than the rate at which state of the art X86 
computer systems run the same programs. Moreover, often these emulator 
programs are not able to run all or a large number of the target programs 
available. 

20 The reasons why emulator programs are not able to run target programs as 
rapidly as the target microprocessors is quite complicated and requires some 
understanding of the different emulation operations. Figure 1 includes a 
series of diagrams representing the different ways in which a plurality of 
different types of microprocessors execute target application programs. 

25 In Figure 1(a), a typical CISC microprocessor such as an Intel X86 

microprocessor is shown running a target application program which is 
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designed to be run on that target processor. As may be seen, the application is 
run on the CISC processor using a CISC operating system (such as MS DOS, 
Windows 3.1, Windows NT, and OS/2 which are used with X86 computers) 
designed to provide interfaces by which access to the hardware of the 

5 computer may be gained. Typically, the instructions of the application 

program are selected to utilize the devices of the computer only through the 
access provided by the operating system. Thus, the operating system handles 
the manipulations which allow applications access to memory and to the 
various input/ output devices of the computer. The target computer includes 

10 memory and hardware which the operating system recognizes, and a call to the 
operating system from a target application causes an operating system device 
driver to cause an expected operation to occur with a defined device of the 
target computer. The instructions of the application execute on the processor 
where they are changed into operations (embodied in microcode or the more 

15 primitive operations from which microcode is assembled) which the processor 
is capable of executing. As has been described above, each time a complicated 
target instruction is executed, the instruction calls the same subroutine stored 
as microcode (or as the same set of primitive operations). The same 
subroutine is always executed. If the processor is a superscalar, these 

20 primitive operations for carrying out a target instruction can often be reordered 
by the processor, rescheduled, and executed using the various processing 
channels in the manner described above; however, the subroutine is still 
fetched and executed. 

In Figure 1(b), a typical RISC microprocessor such as a PowerPC 
25 microprocessor used in an Apple Macintosh computer is represented running 
the same target application program which is designed to be run on the CISC 
processor of Figure 1(a). As may be seen, the target application is run on the 
host processor using at least a partial target operating system to respond to a 
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portion of the calls which the target application generates. Typically these are 
calls to the application-like portions of the target operating system used to 
provide graphical interfaces on the display and short utility programs which 
are generally application-like. The target application and these portions of the 
target operating system are changed by a software emulator such as Soft PC® 
which breaks the instructions furnished by the target application program and 
the application-like target operating system programs into instructions which 
the host processor and its host operating system are capable of executing. The 
host operating system provides the interfaces through which access to the 
memory and input/ output hardware of the RISC computer may be gained. 

However, the host RISC processor and the hardware devices associated with it 
in a host RISC computer are usually quite different than are the devices 
associated with the processor for which the target application was designed; 
and the various instructions provided by the target application program are 
designed to cooperate with the device drivers of the target operating system in 
accessing the various portions of the target computer. Consequently, the 
emulation program, which changes the instructions of the target application 
program to primitive host instructions which the host operating system is 
capable of utilizing, must somehow link the operations designed to operate 
hardware devices in the target computer to operations which hardware devices 
of the host system are capable of implementing. Often this requires the 
emulator software to create virtual devices which respond to the instructions of 
the target application to carry out operations which the host system is 
incapable of carrying out because the target devices are not those of the host 
computer. Sometimes the emulator is required to create links from these 
virtual devices through the host operating system to host hardware devices 
which are present but are addressed in a different manner by the host 
operating system. 
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Tai^et programs when executed in tJiis manner run relatively slowly for a 
number of reasons. First, each target instruction from a target application 
program and from the target operating system must be changed by the 
emulator into the host primitive functions used by the host processor. If the 
5 target application is designed for a CISC machine such as an X86, the target 
instructions are of varying lengths and quite complicated so that changing 
them to host primitive instructions is quite involved. The original target 
instructions are first decoded, and the sequence of primitive host instructions 
which make up the target instructions are determined. Then the address (or 

10 addresses) of each sequence of primitive host instructions is determined, each 
sequence of the primitive host instructions is fetched, and these primitive host 
instructions are executed in or out of order. The large number of extra steps 
required by an emulator to change the target application and operating system 
instructions into host instructions understood by the host processor must be 

15 conducted each time an instruction is executed and slows the process of 
emulation. 

Second, many target instructions include references to operations conducted 
by particular hardware devices which function in a particular manner in the 
target computer, hardware which is not available in the host computer. To 

20 carry out the operation, the emulation software must either make software 

connections to the hardware devices of the host computer through the existing 
host operating system or the emulator software must furnish a virtual 
hardware device. Emulating the hardware of another computer in software is 
very difficult. The emulation software must generate virtual devices for each of 

25 the target apphcation calls to the host operating system; and each of these 
virtual devices must provide calls to the actual host devices. Emulating a 
hardware device requires that when a target instruction is to use the device, 
the code representing the virtual device required by that instruction be fetched 
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from memory and run to implement the device. Either of these methods of 
solving the problem adds another series of operations to the execution of the 
sequence of instructions. 

Complicating the problem of emulation is the requirement that the target 

5 application take various exceptions which are carried out by hardware of the 
target computer and the target operating system in order for the computer 
system to operate. When a target exception is taken during the operation of a 
target computer, state of the computer at the time of the exception must be 
saved typically by calling a microcode sequence to accomplish the operation, 

10 the correct exception handler must be retrieved, the exception must be 

handled, then the correct point in the program must be found for continuing 
with the program. Sometimes this requires that the program revert to the 
state of the target computer at the point the exception was taken, and at other 
times a branch provided by the exception handler is taken. In any case, the 

15 hardware and software of the target computer required to accomplish these 
operations must somehow be provided in the process of emulation. Because 
the correct target state must be available at the time of any such exception for 
proper execution, the emulator is forced to keep accurate track of this state at 
all times so that it is able to correctly respond to these exceptions. In the prior 

20 art, this has required executing each instruction in the order provided by the 
target application because only in this way could correct target state be 
maintained. 

Moreover, prior art emulators have always been required to maintain the order 
of execution of the target application for other reasons. Target instructions 
25 can be of two types, ones which affect memory or ones which affect a memory 
mapped input/ output (I/O) device. There is no way to know without 
attempting to execute an instruction whether an operation is to affect memory 
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or a memory-mapped I/O device. When instructions operate on memory, 
optimizing and reordering is possible and greatly aids in speeding the 
operation of a system. However, operations affecting I/O devices often must be 
practiced in the precise order in which those operations are programmed 
5 without the elimination of amy steps or they may have some adverse effect on 
the operation of the I/O device. For example, a particular I/O operation may 
have the effect of clearing an I/O register. If the operations take place out of 
order so that a register is cleared of a value which is still necessary, then the 
result of the operation may be different than the operation commanded by the 

10 target instruction. Without a means to distinguish memory from memory 
mapped I/O, it is necessary to treat all instructions as though they affect 
memory mapped I/O. This severely restricts the nature of optimizations that 
are achievable. Because prior art emulators lack both means to detect the 
nature of the memorj^ being addressed and means to recover from such 

15 failures, they are required to proceed sequentially through the target 

instructions as though each operation affects memory mapped I/O. This 
greatly limits the possibility of optimizing the host instructions. 

Another problem which limits the ability of prior art emulators to optimize the 
host code is caused by self-modifying code. If a target instruction has been 

20 changed to a sequence of host instructions which in turn write back to change 
the original target instruction, then the host instructions are no longer valid. 
Consequently, the emulator must constantly check to determine whether a 
store is to the target code area. All of these problems make this type of 
emulation much slower than running a target application on a target 

25 processor. 

Another example of the type of emulation software shown in figure 1(b) is 
described in an article entitled, "Talisman: Fast and Accurate Multicomputer 
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Simulation," R. C. Bedichek, Laboratory for Computer Sciences, 
Massachusetts Institute of Technology. This is a more complete example of 
translation in that it can emulate a complete research system and run the 
research target operating system. Talisman uses a host UNIX operating 
system. 

In Figure 1(c), another example of emulation is shown. In this case, a PowerPC 
microprocessor used in an Apple Macintosh computer is represented running a 
target application program which was designed to be run on the Motorola 
68000 family CISC processors used in the original Macintosh computers; this 
type of arrangement has been required in order to allow Apple legacy programs 
to run on the Macintosh computers with RISC processors. As may be seen, 
the target application is run on the host processor using at least a partial 
target operating system to respond to the application-like portions of the target 
operating system. A software emulator breaks the instructions furnished by 
the target application program and the application-like target operating system 
programs into instructions which the host processor and its host operating 
system are capable of executing. The host operating system provides the 
interfaces through which access to the memory and input/ output hardware of 
the host computer may be gained. 

Again, the host RISC processor and the devices associated with it in the host 
RISC computer are quite different than are the devices associated with the 
Motorola CISC processor; and the various target instructions are designed to 
cooperate with the target CISC operating system in accessing the various 
portions of the target computer. Consequently, the emulation program must 
link the operations designed to operate hardware devices in the target 
computer to operations which hardware devices of the host system are capable 
of implementing. This requires the emulator to create software virtual devices 
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which respond to the instructions of the target application and to create links 
from these virtual devices through the host operating system to host hardware 
devices which are present but are addressed in a different manner by the host 
operating system. 

5 The target software run in this manner runs relatively slowly for the same 
reasons that the emulation of Figure 1(b) runs slowly. First, each target 
instruction from the target application and from the target operating system 
must be changed by fetching the instruction; and all of the host primitive 
functions derived from that instruction must be run in sequence each time the 

10 instruction is executed. Second, the emulation software must generate virtual 
devices for each of the target application calls to the host operating system; 
and each of these virtual devices must provide calls to the actual host devices. 
Third, the emulator must treat all instructions as conservatively as it treats 
instructions which arc directed to memory mapped I/O devices or risk 

15 generating exceptions from which it cannot recover. Finally, the emulator 
must maintain the correct target state at all times and store operations must 
always check ahead to determine whether a store is to the target code area. All 
of these requirements eliminate the ability of the emulator to practice 
significant optimization of the code run on the host processor and make this 

20 type of emulation much slower than running the target application on a target 
processor. Emulation rates less than one-quarter as fast as state of the art 
processors are considered very good. In general, this has relegated this type of 
emulation software to uses where the capability of running applications 
designed for another processor is useful but not primary. 

25 In Figure 1(d), a particular method of emulating a target application program 
on a host processor which provides relatively good performance for a very 
limited series of target applications is illustrated. The target application 
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furnishes instructions to an emulator which changes those instructions into 
instructions for the host processor and the host operating system. The host 
processor is a Digital Equipment Corporation Alpha RISC processor, and the 
host operating system is Microsoft NT. The only target applications which may 
5 be run by this system are 32 bit applications designed to be executed by a 
target X86 processor with a Windows WIN32S compliant operating system. 
Since the host and target operating systems are almost identical, being 
designed to handle these same instructions, the emulator software may change 
the instructions very easily. Moreover, the host operating system is already 
10 designed to respond to the same calls that the target application generates so 
that the generation of virtual devices is considerably reduced. 

Although this is technically an emulation system running a target application 
on a host processor, it is a very special case. Here the emulation software is 
running on a host operating system already designed to run similar 

15 applications. This allows the calls from the target applications to be more 
simply directed to the correct facilities of the host and the host operating 
system. More importantly, this system will run only 32 bit Windows 
applications which probably amount to less than one percent of all X86 
applications. Moreover, this system will run applications on only one 

20 operating system, Windows NT; while X86 processors run applications 

designed for a large number of operating systems. Such a system, therefore, 
could be considered not to be compatible within the terms expressed earlier in 
this specification. Thus, a processor running such an emulator cannot be 
considered to be a competitive X86 processor. 

25 Another method of emulation by which software may be used to run portions 
of applications written for a first instruction set on a computer which 
recognizes a different instruction set is illustrated in Figure 1(e). This form of 
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emulation software is typically utilized by a programmer who may be porting 
an application from one computer system to another. Typically, the target 
application is being designed for some target computer other than the host 
machine on which the emulator is being run. The emulator software analyzes 
the target instructions, translates those instructions into instructions which 
may be run on the host machine, and caches those host instructions so that 
they may be reused. This dynamic translation and caching allows portions of 
applications to be run very rapidly. This form of emulator is normally used 
with software tracing tools to provide detailed information about the behavior 
of a target program being run. The output of a tracing tool may, in turn, be 
used to drive an analyzer program which analyzes the trace information. 

In order to determine how the code actually functions, an emulator of this 
type, among other things, runs with the host operating system on the host 
machine, furnishes the virtual hardware which the host operating system does 
not provide, and otherwise maps the operations of the computer for which the 
application was designed to the hardware resources of the host machine in 
order to carry out the operations of the program being run. This software 
virtualizing of hardware and mapping to the host computer can be very slow 
and incomplete. 

Moreover, because it often requires a plurality of host instructions to carry out 
one of the target instructions, exceptions including faults and traps which 
require a target operating system exception handler may be generated and 
cause the host to cease processing the host instructions at a point unrelated to 
target instruction boundaries. When this happens, it may be impossible to 
handle the exception correctly because the state of the host processor and 
memory is incorrect. If this is the case, the emulator must be stopped and 
rerun to trace the operations which generated the exception. Thus, even 
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though such an emulator may run sequences of target code very rapidly, it has 
no method for recovering from these exceptions so cannot run any significant 
portion of an application rapidly. 

This is not a particular problem with this form of emulator because the 
functions being performed by the emulators, tracers, and the associated 
analyzers are directed to generating new programs or porting old programs to 
another machine so that the speed at which the emulator software runs is 
rarely at issue. That is, a programmer is usually not interested in how fast the 
code produced by a emulator runs on the host machine but in whether the 
emulator produces code which is executable on the machine for which it is 
designed and which will run rapidly on that machine. Consequently, this type 
of emulation software does not provide a method for running application 
programs written in a first instruction set to run on a different type of 
microprocessor for other than programming purposes. An example of this type 
of emulation software is described in an article entitled, "Shade: A Fast 
Instruction-Set Simulator for Execution Profiling," Cmelik and Keppel. 

It is desirable to provide competitive microprocessors which are faster and less 
expensive than state of the art microprocessors yet are entirely compatible 
with target application programs designed for state of the art microprocessors 
running any operating systems available for those microprocessors. 

More particularly, it is desirable to provide circuitry for handling host 
processor memory stores in a manner allowing rapid recovery from exceptions 
thereby enhancing the speed at which the processor functions. 
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Summary Of The Invention 

It is, therefore, an object of the present invention to enhance the operation of a 
microprocessor with apparatus for accelerating memory stores generated 
during the execution of programs. 

5 This and other objects of the present invention are realized by apparatus and a 
method including a buffer for temporarily holding apart from other memory 
stores all memory stores sequentially generated during a translation interval 
by a host processor translating a sequence of target instructions into host 
instructions, circuitry for transferring memory stores sequentially generated 

10 during a translation interval to memory if the translation executes without 
generating an exception, circuitry for indicating which memory stores to 
identical memory addresses are most recent in response to a memory access at 
the memory address, and circuitry for eliminating memory stores sequentially 
generated during a translation interval if the translation executes without 

15 generating an exception. 

These and other objects and features of the invention will be better understood 
by reference to the detailed description which follows taken together with the 
drawings in which like elements are referred to by like designations 
throughout the several views. 

20 Brief Description Of The Drawings 

Figures l(a)-(e) are diagrams illustrating the manner of operation of 
microprocessors designed in accordance with the prior art. 

Figure 2 is a block diagram of a microprocessor designed to run an application 
designed for a different microprocessor. 
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Figure 3 is a diagram illustrating a portion of the microprocessor shown in 
Figure 2. 

Figure 4 is a block diagram illustrating a register file used in a microprocessor 
such as that illustrated in Figure 3. 

Figure 5 is a block diagram illustrating a gated store buffer designed in 
accordance with the present invention. 

Figure 6(a)-(c) illustrate instructions used in various microprocessors of the 
prior art and in a microprocessor such as that illustrated in Figure 3. 

Figure 7 illustrates a method practiced by a software portion of a 
microprocessor such as that illustrated in Figure 3. 

Figure 8 illustrates another method practiced by a software portion of a 
microprocessor such as that illustrated in Figure 3. 

Figure 9 is a block diagram illustrating an improved computer system such as 
that illustrated in Figure 3. 

Figure 10 is a block diagram illustrating a portion of the microprocessor shown 
in Figure 3. 

Figure 1 1 is a block diagram illustrating in more detail a translation look aside 
buffer shown in the microprocessor of Figure 3. 

Figure 12 is a block diagram illustrating in detail memory used in a processor 
such as that illustrated in Figure 3. 

Figure 13 is a block diagram illustrating a first logical embodiment of a gated 
store buffer in accordance with the present invention. 
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Figure 14 is a block diagram illustrating a second embodiment of a gated store 
buffer in accordance with the present invention. 

Notation And Nomenclature 

Some portions of the detailed descriptions which follow are presented in terms 
of symbolic representations of operations on data bits within a computer 
memory. These descriptions and representations are the means used by those 
skilled in the data processing arts to most effectively convey the substance of 
their work to others skilled in the art. The operations are those requiring 
physical manipulations of physical quantities. Usually, though not 
necessarily, these quantities take the form of electrical or magnetic signals 
capable of being stored, transferred, combined, compared, and otherwise 
manipulated. It has proven convenient at times, principally for reasons of 
common usage, to refer to these signals as bits, values, elements, symbols, 
characters, terms, numbers, or the like. It should be borne in mind, however, 
that all of these and similar terms are to be associated with the appropriate 
physical quantities and are merely convenient labels applied to these 
quantities. 

Further, the manipulations performed are often referred to in terms, such as 
adding or comparing, which are commonly associated with mental operations 
performed by a human operator. No such capability of a human operator is 
necessary or desirable in most cases in any of the operations described herein 
which form part of the present invention; the operations are machine 
operations. Useful machines for performing the operations of the present 
invention include general purpose digital computers or other similar devices. 
In all cases the distinction between the method operations in operating a 
computer and the method of computation itself should be borne in mind. The 
present invention relates to a method and apparatus for operating a computer 
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in processing electrical or other (e.g. mechanical, chemical) physical signals to 
generate other desired physical signals. 

During the following description, in some cases the target program is referred 
to as a program which is designed to be executed on an X86 microprocessor in 
order to provide exemplary details of operation because the majority of 
emulators run X86 applications. However, the target program may be one 
designed to run on any family of target computers. This includes target virtual 
computers, such as Pcode machines, Postscript machines, or Java virtual 
machines. 

Detailed Description 

The present invention helps overcome the problems of the prior art and provide 
a microprocessor which is faster than microprocessors of the prior art, is 
capable of running all of the software for all of the operating systems which 
may be run by a large number of families of prior art microprocessors, yet is 
less expensive than prior art microprocessors. 

Rather than using a microprocessor with more complicated hardware to 
accelerate its operation, the processor is a part of a combination including an 
enhanced hardware processing portion (referred to as a "morph host" in this 
specification) which is much simpler than stale of the art microprocessors and 
an emulating software portion (referred to as "code morphing software" in this 
specification) in a manner that the two portions function together as a 
microprocessor with more capabilities than any known competitive 
microprocessor. More particularly, a morph host is a processor which includes 
hardware enhancements to assist in having state of a target computer 
immediately at hand when an exception or error occurs, while code morphing 
software is software which translates the instructions of a target program to 
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morph host instructions for the morph host and responds to exceptions and 
errors by replacing working state with correct target state when necessary so 
that correct retranslations occur. Code morphing software may also include 
various processes for enhancing the speed of processing. Rather than 
providing hardware to enhance the speed of processing as do all of the very 
fast prior art microprocessors, the improved microprocessor allows a large 
number of acceleration enhancement techniques to be carried out in selectable 
stages by the code morphing software. Providing the speed enhancement 
techniques in the code morphing software allows the morph host to be 
implemented using much less complicated hardware which is faster and 
substantially less expensive than the hardware of prior art microprocessors. 
As a comparison, one embodiment including the microprocessor designed to 
run all available X86 applications is implemented by a morph host including 
approximately one-quarter of the number of gates of the Pentium Pro 
microprocessor yet runs X86 applications substantially faster than does the 
Pentium Pro microprocessor or any other known microprocessor capable of 
processing these applications. 

The code morphing software utilizes certain techniques which have previously 
been used only by programmers designing new software or emulating new 
hardware. The morph host includes hardware enhancements especially 
adapted to allow the acceleration techniques provided by the code morphing 
software to be utilized efficiently. These hardware enhancements allow the 
code morphing software to implement acceleration techniques over a broader 
range of instructions. These hardware enhancements also permit additional 
acceleration techniques to be practiced by the code morphing software which 
are unavailable in hardware processors and could not be implemented in those 
processors except at exorbitant cost. These techniques significantly increase 
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the speed of the microprocessor compared to the speeds of prior art 
microprocessors practicing the execution of native instruction sets. 

For example, the code morphing software combined with the enhanced morph 
host allows the use of techniques which allow the reordering and rescheduling 
5 of primitive instructions generated by a sequence of target instructions without 
requiring the addition of significant circuitry. By allowing the reordering and 
rescheduling of a number of target instructions together, other optimization 
techniques can be used to reduce the number of processor steps which are 
necessary to carry out a group of target instructions to fewer than those 
10 required by any other microprocessors which will run the target applications. 

The code morphing software combined with the enhanced morph host 
translates target instructions into instructions for the morph host on the fly 
and caches those host instructions in a memory data structure (referred to in 
this specification as a "translation buffer*'). The use of a translation buffer to 

15 hold translated instructions allows instructions to be recalled without 

rerunning the lengthy process of determining which primitive instructions are 
required to implement each target instruction, addressing each primitive 
instruction, fetching each primitive instruction, optimizing the sequence of 
primitive instructions, allocating assets to each primitive instruction, 

20 reordering the primitive instructions, and executing each step of each 

sequence of primitive instructions involved each time each target instruction is 
executed. Once a target instruction has been translated, it may be recalled 
from the translation buffer and executed without the need for any of these 
myriad of steps. 

25 A primary problem of prior art emulation techniques has been the inability of 
these techniques to handle with good performance exceptions generated during 
the execution of a target program. This is especially true of exceptions 
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generated in running the target application which are directed to the target 
operating system where the correct target state must be available at the time of 
any such exception for proper execution of the exception and the instructions 
which follow. Consequentiy, the emulator is forced to keep accurate track of 
the target state at all times and must constantly check to determine whether a 
store is to the target code area. Other exceptions create similar problems. For 
example, exceptions can be generated by the emulator to detect particular 
target operations which have been replaced by some particular host function. 
In particular, various hardware operations of a target processor may be 
replaced by software operations provided by the emulator software. 
Additionally, the host processor executing the host instructions derived from 
the target instructions can also generate exceptions. All of these exceptions 
can occur either during the attempt to change target instructions into host 
instructions by the emulator, or when the host translations are executed on 
the host processor. An efficient emulation must provide some manner of 
recovering from these exceptions efficiently and in a manner that the exception 
may be correctly handled. None of the prior art does this for all software which 
might be emulated. 

In order to overcome these limitations of the prior art, a number of hardware 
improvements are included in the enhanced morph host. These improvements 
include a gated store buffer and a large plurality of additional processor 
registers. Some of the additional registers allow the use of register renaming to 
lessen the problem of instructions needing the same hardware resources. The 
additional registers also allow the maintenance of a set of host or working 
registers for processing the host instructions and a set of target registers to 
hold the official state of the target processor for which the target application 
was created. The target (or shadow) registers are connected to their working 
register equivalents through a dedicated interface that allows an operation 
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called "commit** to quickly transfer the content of all working registers to 
official target registers and allows an operation called "rollback" to quickly 
transfer the content of all official target registers back to their working register 
equivalents. The gated store buffer stores working memory state changes on 
an "uncommitted" side of a hardware "gate" and official memory state changes 
on a "committed" side of the hardware gate where these committed stores 
"drain" to main memory. A commit operation transfers stores from the 
uncommitted side of the gate to the committed side of the gate. The additional 
official registers and the gated store buffer allow the state of memory and the 
state of the target registers to be updated together once one or a group of 
target instructions have been translated and run without error. 

These updates are chosen by the code morphing software to occur on integral 
target instruction boundaries. Thus, if the primitive host instructions making 
up a translation of a series of target instructions are run by the host processor 
without generating exceptions, then the working memory stores and working 
register state generated by those instructions are transferred to official memory 
and to the official target registers. In this manner, if an exception occurs when 
processing the host instructions at a point which is not on the boundary of one 
or a set of target instructions being translated, the original state in the target 
registers at the last update (or commit) may be recalled to the working 
registers and uncommitted memory stores in the gated store buffer may be 
dumped. Then, for the case where the exception generated is a target 
exception, the target instructions causing the target exception may be 
retranslated one at a time and executed in serial sequence as they would be 
executed by a target microprocessor. As each target instruction is correctly 
executed without error, the state of the target registers may be updated; and 
the data in the store buffer gated to memoiy. Then, when the exception occurs 
again in running the host instructions, the correct state of the target computer 
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is held by the target registers of the morph host and memory; and the 
operation may be correctly handled without delay. Each new translation 
generated by this corrective translating may be cached for future use as it is 
translated or alternatively dumped for a one time or rare occurrence such as a 
page fault. This allows the microprocessor created by the combination of the 
code morphing software and the morph host to execute the instructions more 
rapidly than processors for which the software was originally written. 

It should be noted that in executing target programs using the microprocessor 
including the present invention, many different types of exceptions can occur 
which are handled in different manners. For example, some exceptions are 
caused by the target software generating an exception which utilizes a target 
operating system exception handler. The use of such an exception handler 
requires that the code morphing software include routines for emulating the 
entire exception handling process including any hardware provided by the 
target computer for handling the process. This requires that the code 
morphing software provide for saving the state of the target processor so that it 
may proceed correctly after the exception has been handled. Some exceptions 
like a page fault, which requires fetching data in a new page of memory before 
the process being translated may be implemented, require a return to the 
beginning of the process being translated after the exception has been 
handled. Other exceptions implement a particular operation in software where 
that operation is not provided by the hardware. These require that the 
exception handler return the operation to the next step in the translation after 
the exception has been handled. Each of these different types of exceptions 
may be efficiently handled by microprocessor including the present invention. 

Additionally, some exceptions are generated by host hardware and detect a 
variety of host and target conditions. Some exceptions behave like exceptions 
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on a conventional microprocessor, but others are used by the code morphing 
software to detect failure of various speculations. In these cases, the code 
morphing software, using the state saving and restoring mechanisms 
described above, causes the target state to be restored to its most recent 
official version and generates and saves a new translation (or re-uses a 
previously generated safe translation) which avoids the failed speculation. 
This translation is then executed. 

The morph host includes additional hardware exception detection mechanisms 
that in conjunction with the rollback and retranslate method described above 
allow further optimization. Examples are a means to distinguish memory from 
memory mapped I/O and a means to eliminate memory references by 
protecting addresses or address ranges thus allowing target variables to be 
kept in registers. 

For the case where exceptions are used to detect failure of other speculations, 
such as whether an operation affects memory or memory mapped I/O, 
recovery is accomplished by the generation of new translations with different 
memory operations and different optimizations. 

Figure 2 is a diagram of morph host hardware represented running the same 
application program which is being run on the CISC processor of Figure 1(a). 
As may be seen, the microprocessor includes the code morphing software 
portion and the enhanced hardware morph host portion described above. The 
target application furnishes the target instructions to the code morphing 
software for translation into host instructions which the morph host is capable 
of executing. In the meantime, the target operating system receives calls from 
the target application program and transfers these to the code morphing 
software. In a preferred embodiment of the microprocessor, the morph host is 
a very long instruction word (VLIW) processor which is designed with a 
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plurality of processing channels. The overall operation of such a processor is 
further illustrated in Figure 6(c). 

In Figure 6(a) -(c) are illustrated instructions adapted for use with each of a 
CISC processor, a RISC processor, and a VLIW processor. As may be seen, the 
CISC instructions are of varied lengths and may include a plurality of more 
primitive operations (e.g., load and add). The RISC instructions, on the other 
hand, are of equal length and are essentially primitive operations. The single 
very long instruction for the VLIW processor illustrated includes each of the 
more primitive operations (i.e., load, store, integer add, compare, floating point 
multiply, and branch) of the CISC and RISC instructions. As may be seen in 
Figure 6(c), each of the primitive instructions wrhich together make up a single 
very long instruction word is furnished in parallel with the other primitive 
instructions either to one of a plurality of separate processing channels of the 
VLIW processor or to memory to be dealt v^dth in parallel by the processing 
channels and memory. The results of all of these parallel operations are 
transferred into a multiported register file. 

A VLIW processor which may be the basis of the morph host is a much simpler 
processor than the other processors described above . It does not include 
circuitry to detect issue dependencies or to reorder, optimize, and reschedule 
primitive instructions. This, in turn, allows faster processing at higher clock 
rates than is possible with either the processors for which the target 
application programs were originally designed or other processors using 
emulation programs to run target application programs. However, the 
processor is not limited to VLIW processors and may function as well with any 
type of processor such as a RISC processor. 
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The code morphing software of the microprocessor shown in Figure 2 includes 
a translator portion which decodes the instructions of the target application, 
converts those target instructions to the primitive host instructions capable of 
execution by the morph host, optimizes the operations required by the target 
5 instructions, reorders and schedules the primitive instructions into VLIW 
instructions (a translation) for the morph host, and executes the host VLIW 
instructions. The operations of the translator are illustrated in Figure 7 which 
illustrates the operation of the main loop of the code morphing software. 

In order to accelerate the operation of the microprocessor which includes the 
10 code morphing software and the enhanced morph host hardware, the code 
morphing software includes a translation buffer as is illustrated in Figure 2. 
The translation buffer of one embodiment is a software data structure which 
may be stored in memory; a hardware cache might also be utilized in a 
particular embodiment. The translation buffer is used to store the host 
15 instructions which embody each completed translation of the target 

instructions. As may be seen, once the individual target instructions have 
been translated and the resulting host instructions have been optimized, 
reordered, and rescheduled, the resulting host translation is stored in the 
translation buffer. The host instructions which make up the translation are 
20 then executed by the morph host. If the host instructions are executed 

without generating an exception, the translation may thereafter be recalled 
whenever the operations required by the target instruction or instructions are 
required. 

Thus, as shown in Figure 7, a typical operation of the code morphing software 
25 of the microprocessor when furnished the address of a target instruction by 
the application program is to first determine whether the target instruction at 
the target address has been translated. If the target instruction has not been 
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translated, it and subsequent target instructions are fetched, decoded, 
translated, and then (possibly) optimized, reordered, and rescheduled into a 
new host translation, and stored in the translation buffer by the translator. As 
will be seen later, there are various degrees of optimization which are possible. 
The term ''optimization" is often used generically in this specification to refer to 
those techniques by which processing is accelerated. For example, reordering 
is one form of optimization which allows faster processing and which is 
included within the term. Many of the optimizations which are possible have 
been described within the prior art of compiler optimizations, and some 
optimizations which were difficult to perform within the prior art like "super- 
blocks" come from VLIW research. Control is then transferred to the 
translation to cause execution by the enhanced morph host hardware to 
resume. 

When the particular target instruction sequence is next encountered in 
running the application, the host translation will then be found in the 
translation buffer and immediately executed without the necessity of 
translating, optimizing, reordering, or rescheduling. Using the advanced 
techniques described below, it has been estimated that the translation for a 
target instruction (once completely translated) will be found in the translation 
buffer all but once for each one million or so executions of the translation. 
Consequently, after a first translation, all of the steps required for translation 
such as decoding, fetching primitive instructions, optimizing the primitive 
instructions, rescheduling into a host translation, and storing in the 
translation buffer may be ehminated from the processing required. Since the 
processor for which the target instructions were written must decode, fetch, 
reorder, and reschedule each instruction each time the instruction is executed, 
this drastically reduces the work required for executing the target instructions 
and increases the speed of the improved microprocessor. 
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In eliminating all of Uaese steps required in execution of a target application by 
prior art processors, the microprocessor including the present invention 
overcomes problems of the prior art which made such operations impossible at 
any reasonable speed. For example, some of the techniques of the improved 
microprocessor were used in the emulators described above used for porting 
applications to other systems. However, some of these emulators had no way 
of running more than short portions of applications because in processing 
translated instructions, exceptions which generate calls to various system 
exception handlers were generated at points in the operation at which the state 
of the host processor had no relation to the state of a target processor 
processing the same instructions. Because of this, the state of the target 
processor at the point at which such an exception was generated was not 
known. Thus, correct state of the target machine could not be determined; 
and the operation would have to be stopped, restarted, and the correct state 
ascertained before the exception could be serviced and execution continued. 
This made running an application program at host speed impossible. 

The morph host hardware includes a number of enhancements which 
overcome this problem. These enhancements are each illustrated in Figures 3, 
4, and 5. In order to determine the correct state of the registers at the time an 
error occurs, a set of official target registers is provided by the enhanced 
hardware to hold the state of the registers of the target processor for which the 
original application was designed. These target registers may be included in 
each of the floating point units, any integer units, and any other execution 
units. These official registers have been added to the morph host along with 
an increased number of normal working registers so that a number of 
optimizations including register renaming may be practiced. One embodiment 
of the enhanced hardware includes sixty-four working registers in the integer 
unit and thirty-two working registers in the floating point unit. The 



wo 98/28689 PCT/US97/22768 

31 

embodiment also includes an enhanced set of target registers which include all 
of the frequently changed registers of the target processor necessary to provide 
the state of that processor ; these include condition control registers and other 
registers necessary for control of the simulated system. 

It should be noted that depending on the type of enhanced processing 
hardware utilized by the morph host, a translated instruction sequence may 
include primitive operations which constitute a plurality of target instructions 
from the original application. For example, a VLIW microprocessor may be 
capable of running a plurality of either CISC or RISC instructions at once as is 
illustrated in Figure 6(a)-(c). Whatever the morph host type, the state of the 
target registers of the morph host hardware is not changed except at an 
integral target instruction boundary; and then all target registers are updated. 
Thus, if the microprocessor is executing a target instruction or instructions 
which have been translated into a series of primitive instructions which may 
have been reordered and rescheduled into a host translation, when the 
processor begins executing the translated instruction sequence, the official 
target registers hold the values which would be held by the registers of the 
target processor for which the application was designed when the first target 
instruction was addressed. After the morph host has begun executing the 
translated instructions, however, the working registers hold values determined 
by the primitive operations of the translated instructions executed to that 
point. Thus, while some of these working registers may hold values which are 
identical to those in the official target registers, others of the working registers 
hold values which are meaningless to the target processor. This is especially 
true in an embodiment which provides many more registers than does a 
particular target machine in order to allow advanced acceleration techniques. 
Once the translated host instructions begin, the values in the working 
registers are whatever those translated host instructions determine the 
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condition of those registers to be. If a set of translated host instructions is 
executed without generating an exception, then the new working register 
values determined at the end of the set of instructions are transferred together 
to the official target registers (possibly including a target instruction pointer 
register). In the present embodiment of the processor, this transfer occurs 
outside of the execution of the host instructions in an additional pipeline stage 
so it does not slow operation of the morph host. 

In a similar manner, a gated store buffer such as that in the embodiment 
illustrated in Figure 5 is utilized in the hardware of the improved 
microprocessor to control the transfer of data to memory. The gated store 
buffer includes a number of elements each of which may act as a storage 
location to hold the address and data for a memory store operation. These 
elements may be implemented by any of a number of different hardware 
arrangements {e.g., first-in first-out buffers); the embodiment illustrated is 
implemented utilizing random access memory and three dedicated working 
registers. The three registers store, respectively, a pointer to the head of the 
queue of memory stores, a pointer to the gate, and a pointer to the tail of the 
queue of the memory stores. A pointer is also is also stored in a separate 
register (not shown in Figure 5) which designates the element from which data 
is being drained to memory. Memoiy stores positioned in the storage locations 
between the head of the queue and the gate are already committed to memory, 
while those positioned in the storage locations separated or segregated from 
other locations between the gate of the queue and the tail are not yet 
committed to memory. Memory stores generated during execution of host 
translations are placed in the store buffer by the integer unit in the order 
generated during the execution of the host instructions by the morph host but 
are not allowed to be written to memory until a commit operation is 
encountered in a host instruction. Thus, as translations execute, the store 
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operations are placed in the queue. Assuming these are the first stores so that 
no other stores are in the gated store buffer, both the head and gate pointers 
will point to the same position. As each store is executed, it is placed in the 
next position in the queue and the tail point is incremented to the next 
position (upward in the figure). This continues until a commit command is 
executed. This will normally happen when the translation of a set of target 
instructions has been completed without generating an exception or a error 
exit condition. When a translation has been executed by the morph host 
without error, then the memory stores in the store buffer generated during 
execution are moved together past the gate of the store buffer (committed) and 
subsequently written to memory. In the embodiment illustrated, this is 
accomplished by copying the value in the register holding the tail pointer to the 
register holding the gate pointer. 

Thus, it may be seen that both the transfer of register state from working 
registers to official target registers and the transfer of working memory stores 
to official memory occur together and only on boundaries between integral 
target instructions in response to explicit commit operations. 

This allows the microprocessor to recover from target exceptions which occur 
during execution by the enhanced morph host without any significant delay. If 
a target exception is generated during the running of any translated 
instruction or instructions, that exception is detected by the morph host 
hardware or software. In response to the detection of the target exception, the 
code morphing software may cause the values retained in the official registers 
to be placed back into the working registers and any non-committed memory 
stores in the gated store buffer to be dumped (an operation referred to as 
"rollback"). The memory stores in the gated store buffer of Figure 5 may be 
dumped by copying the value in the register holding the gate pointer to the 
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register holding the tail pointer. 

Placing the values from the target registers into the working registers may 
place the address of the first of the target instructions which were running 
when the exception occurred in the working instruction pointer register. 
Beginning with this official state of the target processor in the working 
registers, the target instructions which were running when the exception 
occurred are retranslated in serial order without any reordering or other 
optimizing. After each target instruction is newly decoded and translated into 
a new host translation, the translated host instruction representing the target 
instructions is executed by the morph host and causes or does not cause an 
exception to occur. (If the morph host is other than a VLIW processor, then 
each of the primitive operations of the host translation is executed in 
sequence. If no exception occurs as the host translation is run, the next 
primitive function is run.) This continues until an exception re-occurs or the 
single target instruction has been translated and executed. In one 
embodiment, if a translation of a target instruction is executed without an 
exception being generated, then the state of working registers is transferred to 
the target registers and any data in the gated store buffer is committed so that 
it may be transferred to memory. However, if an exception re-occurs during 
the running of a translation, then the state of the target registers and memory 
has not changed but is identical to the state produced in a target computer 
when the exception occurs. Consequently, when the target exception is 
generated, the exception will be correctly handled by the target operating 
system. 

Similarly, once a first target instruction of the series of instructions the 
translation of which generated an exception has been executed without 
generating an exception, the target instruction pointer points to the next of the 
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target instructions. This second target instruction is decoded and retranslated 
without optimizing or reordering in the same manner as the first. As each of 
the host translations of a single target instruction is processed by the morph 
host, any exception generated will occur when the state of the target registers 
and memory is identical to the state which would occur in the target computer. 
Consequently, the exception may be immediately and correctly handled. These 
new translations may be stored in the translation buffer as the correct 
translations for that sequence of instructions in the target application and 
recalled whenever the instructions are rerun. 

Other embodiments for accomplishing the same result as the gated store buffer 
of Figure 5 might include arrangements for transferring stores directly to 
memory while recording data sufficient to recover state of the target computer 
in case the execution of a translation results in an exception or an error 
necessitating rollback. In such a case, the effect of any memory stores which 
occurred during translation and execution would have to be reversed and the 
memory state existing at the beginning of the translation restored; while 
working registers would have to receive data held in the official target registers 
in the manner discussed above. One embodiment for accomplishing this 
maintains a separate target memory to hold the original memory state which, is 
then utilized to replace overwritten memory if a rollback occurs. Another 
embodiment for accomplishing memory rollback logs each store and the 
memory data replaced as they occur, and then reverses the store process if 
rollback is required. 

Implementing the gated store buffer described in detail above presents a 
number of problems. For example, data may be constantly being stored to the 
same memory address during operation of the microprocessor. At any time 
before the data of any such store has actually been sent to memory, that data 



wo 98/286S9 PCT/US5^/22768 

may be required for other operations by the microprocessor. Usually, the data 
which should be used is the latest valid data available. In a typical store 
buffer, data transferred to the same memory address in a buffer as the address 
of data already in the buffer is normally stored in place of the older data. 
Consequently, the latest data is always immediately available from the buffer 
without more than searching for valid data at the address. 

However, this is not possible with the gated store buffer described because the 
buffer is specifically devised to hold memory stores from operations which have 
not yet been determined to be final. Before these stores are committed to 
memory, it must be determined that the sequence of instructions generating 
the stores will execute correctly. Consequently, to save a later-occurring 
memory store in a buffer location in place of an earlier memory store which 
has been committed would be to effectively commit the new store data before 
the execution of the host instructions generating that data had been completed 
without generating an exception. This would defeat the entire purpose of the 
gated store buffer. 

Consequently, in one embodiment of the gated store buffer, new memory stores 
are not stored in place of older stores to the same address but are stored 
sequentially in a separate or segregated portion of the buffer as they occur; 
and there may be a number of stores to the same memory address in the gated 
store buffer at any instant, some of those stores committed to memory and 
others of those stores as yet uncommitted. Each storage location in the gated 
store buffer includes some designation of the validity of the data in the 
location. In the embodiment the logical arrangement of which is shown in 
Figure 13, a valid bit (in columns designated V) is provided for each byte of 
data (the minimum addressable amount of data in the embodiment) at a 
storage location in the gated store buffer. Typically, sixty-four bits are 
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available to store data at each buffer storage location so eight individual bytes 
each with its own valid bit are included at each storage location in the buffer. 

In order to distinguish the most recent store to a memory address held in the 
buffer, each byte of each storage location is also provided a first bit (in 
columns designated M) which is used to indicate that the bj^te is the most 
recent byte of data at that memory address. Each memory location includes 
comparison circuitry which tests the memoiy address (including byte address) 
and control bits of each new write to the gated store buffer. When new data is 
stored to a storage location of the store buffer, each byte of the newly-stored 
data has its most-recently- stored bit asserted. If the newly-stored data is 
being stored at a memory address identical to a memory address of valid data 
already in the gated store buffer, the comparison circuitry determines this on a 
byte basis and deasserts the most-recent bits for any bytes at the same 
memory address which were formerly the most-recently stored. In this 
manner, a need for the most recent data for a load of data at that memory 
address is satisfied by detecting data at a particular memory address with its 
most-recent bit(s) asserted. 

It may be seen that in this embodiment instead of writing over the older data 
stored in the gated store buffer for the memory address as in the prior art, the 
older data is eliminated virtually for the purpose of loads from that address to 
microprocessor registers by deasserting the older most-recent bits associated 
with it. The deassertion of the most recent bit for a byte at a memory address 
being accessed for a load causes that byte to be ignored while those bytes for 
the same address marked by most-recent bits are read from the store buffer for 
the load operation. At the same time, the data at the location which is no 
longer the most recent remains in the store buffer so that it may ultimately be 
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committed to memory in the sequential order in which it is placed in the gated 
store buffer. 

Because the data in the gated store buffer is subject to commit and rollback 
operations in order to effect the accelerated performance of the microprocessor 
in the manner described above, it is possible for data in an uncommitted store 
to be dumped (eliminated) during a rollback operation. This data is always 
more recent than any committed data at the same memory address held in the 
gated store buffer. Consequently, if committed data exists at another storage 
location in the gated store buffer with the same memory address as 
uncommitted data which is being dumped, then after the rollback the most 
recent of the committed data at the memoiy address will be the most recent 
data remaining in the store buffer at the memory address and should be so 
indicated. However, the most recent bit on this committed data will have been 
deasserted when the newer uncommitted data at the same address (which has 
now been dumped) was placed in the gated store buffer. 

In order to assure that the most recent data for a memory address remains 
correctly designated after rollback and commit operations, each byte has not 
only a most-recent bit position but also a second "shadowing-most-recent bit" 
position (designated "S" in Figure 13). When data at one or more storage 
locations in the gated store buffer are committed by moving the position of the 
gate to the tail of the buffer, the most recent data at each address stored in the 
buffer has its shadowing-most-recent bit asserted and simultaneously any 
shadowing-most-recent bits for other data for the same memory address which 
are already asserted are deasserted. At the instant this occurs, the newly 
committed data will actually be the most recent data for that memory address 
so all that is required is to copy the most recent bit associated with each byte 
of each storage location being committed to the shadowing-most-recent bit for 
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that byte. When newer data is written to the store buffer for that same 
memory address, the most-recent bit of the committed data is deasserted while 
the shadowing-most-recent bit remains asserted. Then if rollback later occurs 
so that uncommitted data destined for that address which is more recent is 
dumped, the shadowing most recent bits of the most recent of the committed 
data are copied to the most recent bit positions of committed bytes to correctly 
indicate that the most recent committed data is in fact the most recently stored 
data. 

Thus, in the embodiment discussed, it will be seen that the logic utilized to 
write to the gated store buffer writes the new data to the next sequential 
memory location and asserts the valid and most-recent bits for each byte 
written to that location. The logic compares the memory address of the data 
being written to the memory addresses of data at storage locations in the 
buffer to determine whether older data destined for that address is in the 
buffer. If such data is found, older data for the address with a most- recent bit 
asserted has that bit deasserted. On a commit operation, all data with a most- 
recent bit asserted has its shadowing-most-recent bit asserted; and all data 
with a shadowing-most-recent bit asserted has that bit deasserted. On a 
rollback operation, the uncommitted data is dumped and the most-recent bit is 
asserted for committed data with a shadowing-most-recent bit already 
asserted. 

An additional register may be utilized with the embodiment illustrated to store 
a pointer to a memory store location which is next to be drained to memory so 
that data is drained to memory in sequence. As data at each storage location 
is drained to memory, the valid, most-recent, and shadowing-most-recent bits 
for that data are cleared in order to maintain the correct draining sequence. 
This additional register pointing to a storage location being drained may also 
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be used in order to shorten the operation of draining to memory by 
implementing logic to compare all committed data to be stored at each memory 
address and draining only the most recent committed data for a memory 
address to memory while ignoring committed data which is not the most 
5 recent. 

A second embodiment of the gated store buffer is illustrated in Figure 14. This 
embodiment utilizes a plurality of groups of storage locations, each group 
holding a sufficient number of storage locations to hold the stores generated by 
a typical complete translation of a sequence of target instructions; if a greater 

10 number of stores is generated, more than one group is utilized to store the 

translation. As with the embodiment of Figure 13, each storage location of the 
group holds a number of bytes of store data, a memory address, and a valid bit 
for each byte. Each group of storage locations is capable of being designated 
as a working group (e.g., by asserting a bit W associated with the group) in 

15 which store data being generated is currently being stored. The data in a 
working group is all uncommitted. Each group is, however, arranged to be 
addressed as is an associative cache so that new store data written to a 
particular memory address is written over older store data already in the 
working group and written to the same memory address. This is accomplished 

20 in the embodiment illustrated by a comparator at each storage location. In 
this manner, the data addressed to any memory address stored in a group 
exists at only one storage location in that group of storage locations. Thus, if 
data needs to be utilized for loads by the host processor before being 
committed, it may be found by testing for the memory address in the group. 

25 This eliminates the need for a most recent bit and a shadowing-most-recent bit 
as used in the previous embodiment. 
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If a sequence of target instructions are executed without generating an 
exception, the data stores generated by that sequence in a working group are 
committed together. This committing (which is equivalent to moving the gate 
pointer to the position of the tail pointer in the earlier embodiment) may be 
done by asserting a commit bit (bit C) associated with the particular group of 
storage locations and deasserting the working bit (bit W) for that group. Once 
a group of storage locations has been committed, the data in those locations 
may remain in the group until drained to memory. Thus, the circuitry 
necessary to hold the head, gate, and tail pointers to designate committed and 
uncommitted stores are eliminated while the same result is achieved through 
the use of the working and commit bits. 

Thus, if an exception w^hich requires rollback is generated while executing a 
sequence of translated target instructions, the data stored in the working 
group is simply eliminated (dumped). This may be accomplished, for example, 
by removing the working indication stored as the W bit without asserting the 
commit bit. In effect, removing the working indication is equivalent to moving 
the tail pointer to the position of the gate pointer in the earlier embodiment. 

Various combinations of the two embodiments discussed above will be 
apparent to those skilled in the art. For example, the size of the first 
embodiment may be reduced by utilizing logic which allows new data stores to 
be written over old data stores but only within the storage locations between 
the gate and the tail in which data stores have not been committed. In a 
similar manner, logic may be utilized which detects all committed stores with 
identical addresses and only writes the most recent (byte) to memory using the 
drain pointer in the manner indicated above to point to the most recent of the 
committed data. 
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It would also be possible to combine the details of the embodiments described 
above with a typical processor cache so that a single circuit would accomplish 
both purposes. In such a case, it would be necessary to provide means for 
indicating lines of the cache storing committed and uncommitted memory 
stores and well as other control indicators. 

The code morphing software provides an additional operation which greatly 
enhances the speed of processing programs which are being translated. In 
addition to simply translating the instructions, optimizing, reordering, 
rescheduling, caching, and executing each translation so that it may be rerun 
whenever that set of instructions needs to be executed, the translator also 
links the different translations to eliminate in almost all cases a return to the 
main loop of the translation process. Figure 8 illustrates the steps carried out 
by the translator portion of the code morphing software in accomplishing this 
linking process. It will be understood by those skilled in the art that this 
linking operation essentially eliminates the return to the main loop for most 
translations of instructions, which eliminates this overhead. 

Presume for exemplary purposes that the target program being run consists of 
X85 instructions. When a translation of a sequence of target instructions 
occurs and the primitive host instructions arc reordered and rescheduled, two 
primitive instructions may occur at the end of each host translation. The first 
is a primitive instruction which updates the value of the instruction pointer for 
the target processor (or its equivalent); this instruction is used to place the 
correct address of the next target instruction in the target instruction pointer 
register. Following this primitive instruction is a branch instruction which 
contains the address of each of two possible targets for the branch. The 
manner in which the primitive instruction which precedes the branch 
instruction may update the value of the instruction pointer for the target 
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processor is to test the condition code for the branch in the condition code 
registers and then determine whether one of the two branch addresses 
indicated by the condition controlling the branch is stored in the translation 
buffer. The first time the sequence of target instructions is translated, the two 
I 5 branch targets of the host instruction both hold the same host processor 

address for the main loop of the translator software. 

When the host translation is completed, stored in the translation buffer, and 
executed for the first time, the instruction pointer is updated in the target 
instruction pointer register (as are the rest of the target registers); and the 

10 operation branches back to the main loop. At the main loop, the translator 
software looks up the instruction pointer to the next target instruction in the 
target instruction pointer register. Then the next target instruction sequence 
is addressed. Presuming that this sequence of target instructions has not yet 
been translated and therefore a translation does not reside in the translation 

15 buffer, the next set of target instructions is fetched from memory, decoded, 

translated, optimized, reordered, rescheduled, cached in the translation buffer, 
and executed. Since the second set of target instructions follows the first set of 
target instructions, the primitive branch instruction at the end of the host 
translation of the first set of target instructions is automatically updated to 

20 substitute the address of the host translation of the second set of target 

instructions as the branch address for the particular condition controlling the 
brainch. 

If then, the second translated host instruction were to loop back to the first 
translated host instruction, the branch operation at the end of the second 
25 translation would include the main loop address and the X86 address of the 
first translation as the two possible targets for the branch. The update- 
instruction-pointer primitive operation preceding the branch tests the 
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condition and determines that the loop back to the first translation is to be 
taken and updates the target instruction pointer to the X86 address of the first 
translation. This causes the translator to look in the translation buffer to see 
if the X86 address being sought appears there. The address of the first 
translation is found, and its value in host memory space is substituted for the 
X86 address in the branch at the end of the second host translated 
instruction. Then, the second host translated instruction is cached and 
executed. This causes the loop to be run until the condition causing the 
branch from the first translation to the second translation fails, and the 
branch takes the path back to the main loop. When this happens, the first 
translated host instruction branches back to the main loop where the next set 
of target instructions designated by the target instruction pointer is searched 
for in the translation buffer, the host translation is fetched from the cache; or 
the search in the translation buffer fails, and the target instructions are 
fetched from memory and translated. When this translated host instruction is 
cached in the translation buffer, its address replaces the main loop address in 
the branch instruction which ended the loop. 

In this manner, the various translated host instructions are chained to one 
another so that the need to follow the long path through the translator main 
loop only occurs where a link does not exist. Eventually, the main loop 
references in the branch instructions of host instructions are almost 
completely eliminated. When this condition is reached, the time required to 
fetch target instructions, decode target instructions, fetch the primitive 
instructions which make up the target instructions, optimize those primitive 
operations, reorder the primitive operations, and reschedule those primitive 
operations before running any host instruction is eliminated. Thus, in 
contrast to all prior art microprocessors which must take each of these steps 
each time any application instruction sequence is run, the work required to 
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run any set of target instructions using the improved microprocessor after the 
first translation has taken place is drastically reduced. This work is further 
reduced as each set of translated host instructions is linked to the other sets of 
translated host instructions. In fact, it is estimated that translation will be 
5 needed in less than one translation execution out of one million during the 
running of an application. 

Those skilled in the art will recognize that the implementation of the 
microprocessor requires a large translation buffer since each set of 
instructions which is translated is cached in order that it need not be 
10 translated again. Translators designed to function with applications 

programmed for different systems will vary in their need for supporting buffer 
memory. However, one embodiment of the microprocessor designed to run 
X86 programs utilizes a translation buffer of two megabytes of random access 
memory. 

15 Two additional hardware enhancements help to increase the speed at which 
applications can be processed by the microprocessor which includes the 
present invention. The first of these is an abnormal/ normal (A/N) protection 
bit stored with each address translation in a translation look-aside buffer (TLB) 
(see Figure 3) where lookup of the physical address of target instructions is 

20 first accomplished. Target memory operations within translations can be of 
two types, ones which operate on memory (normal) or ones which operate on a 
memory mapped 1/0 device (abnormal). 

A normal access which affects memory completes normally. When instructions 
operate on memory, the optimizing and reordering of those instructions is 
25 appropriate and greatly aids in speeding the operation of any system using the 
microprocessor which includes the present invention. On the other hand, the 
operations of an abnormal access which affects an I/O device often must be 
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practiced in the precise order in which those operations are programmed 
without the ehmination of any steps or they may have some adverse affect at 
the I/O device. For example, a particular I/O operation may have the effect of 
clearing an I/O register; if the primitive operations take place out of order, 
then the result of the operations may be different than the operation 
commanded by the target instruction. Without a means to distinguish 
memory from memory mapped I/O, it is necessary to treat all memory with the 
conservative assumptions used to translate instruction which affect memory 
mapped I/O. This severely restricts the nature of optimizations that are 
achievable. Because prior art emulators lacked means to both detect a failure 
of speculation on the nature of the memory being addressed, and means to 
recover from such failures, their performance was restricted. 

In one embodiment of the microprocessor illustrated in Figure 11, the A/N bit 
is a bit which may be set in the translation look-aside buffer to indicate either 
a memory page or memory-mapped I/O. The translation look-aside buffer 
stores page table entries for memory accesses. Each such entry includes a 
virtual address being accessed and the physical address at which the data 
sought may be accessed as well as other information regarding the entry. The 
A/N bit is part of that other information and indicates whether the physical 
address is a memory address or a memory-mapped I/O address. A translation 
of an operation which affects memory as though it were a memory operation is 
actually a speculation that the operation is one affecting memory. In one 
embodiment, when the code morphing software first attempts to execute a 
translation which requires an access of either memory or a memory-mapped 
I/O device, it is actually presuming that the access is a memory access. In a 
different embodiment, the software might presume the target command 
requires an I/O access. Presuming an access of that address has not 
previously been accomplished, there will be no entry in the translation look- 
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aside buffer; and the access will fail in the translation look-aside buffer. This 
failure causes the software to do a page table lookup and fill a storage location 
of the translation look-aside buffer with the page table entry to provide the 
correct physical address translation for the virtual address. In accomplishing 
this, the software causes the A/N bit for the physical address to be entered in 
the translation look-aside buffer. Then another attempt to execute the access 
takes place once more assuming that the access is of a memory address. As 
the access is attempted, the target memory reference is checked by comparing 
the access type presumed (normal or abnormal) against the A/N protection bit 
now in the TLB page table entry. When the access type does not match the 
A/N protection, an exception occurs. If the operation in fact affects memory, 
then the optimizing, reordering, and rescheduling techniques described above 
were correctly applied during translation. If the comparison with the A/N bit 
in the TLB shows that the operation, however, affects an I/O device, then 
execution causes an exception to be taken; and the translator produces a new 
translation one target instruction at a time without optimizing, reordering, or 
rescheduling of any sort. Similarly, if a translation incorrectly assumes an I/O 
operation for an operation which actually affects memory, execution causes an 
exception to be taken; and the target instructions are retranslated using the 
optimizing, reordering, and rescheduling techniques. In this manner, the 
processor can enhance performance beyond what has been traditionally 
possible. 

It will be recognized by those skilled in the art that the technique which uses 
the A/N bit to determine whether a failure of speculation has occurred as to 
whether an access is to memory or a memory-mapped I/O device may also be 
used for speculations regarding other properties of memory-mapped addresses. 
For example, different types of memory might be distinguished using such a 
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normal/ abnormal bit. Other similar uses is distinguishing memory properties 
will be found by those skilled in the art. 

One of the most frequent speculations practiced by the improved 
microprocessor is that target exceptions will not occur within a translation. 
5 This allows significant optimization over the prior art. First, target state does 
not have to be updated on each target instruction boundary, but only on target 
instruction boundaries which occur on translation boundaries. This 
eliminates instructions necessary to save target state on each target 
instruction boundary. Optimizations that would previously have been 
10 impossible in scheduling and removing redundant operations are also made 
possible. 

The improved microprocessor is admirably adapted to select the appropriate 
process of translation. In accordance with the method of translating described 
above, a set of instructions may first be translated as though it were to affect 

15 memory. When the optimized, reordered, and rescheduled host instructions 
are then executed, the address may be found to refer to an I/O device by the 
condition of the A/N bit provided in the translation look-aside buffer. The 
comparison of the A/N bit and the translated instruction address which shows 
that an operation is an I/O operation generates an error exception which 

20 causes a software initiated rollback procedure to occur, causing any 
uncommitted memory stores to be dumped and the values in the target 
registers to be placed back into the working registers. Then the translation 
starts over, one target instruction at a time without optimization, reordering, 
or rescheduling. This re-translation is the appropriate host translation for an 

25 I/O device. 

In a similar manner, it is possible for a memory operation to be incorrectly 
translated as an I/O operation. The error generated may be used to cause its 
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correct re-translation where it may be optimized, reordered, and rescheduled 
to provide faster operation. 

Prior art emulators have also struggled with what is generally referred to as 
selfmodifying code. Should a target program write to the memory that 
contains target instructions, this will cause translations that exist for these 
target instructions to become "stale" and no longer valid. It is necessaiy to 
detect these stores as they occur dynamically. In the prior art, such detection 
has to be accomplished with extra instructions for each store. This problem is 
larger in scope than programs modifying themselves. Any agent which can 
write to memory, such as a second processor or a DMA device, can also cause 
this problem. 

The present improved microprocessor deals with this problem by another 
enhancement to the morph host. A translation bit (T bit) which may also be 
stored in the translation look-aside buffer is used to indicate target memory 
pages for which translations exist. The T bit thus possibly indicates that 
particular pages of target memory contain target instructions for which host 
translations exist which would become stale if those target instructions were to 
be overwritten. If an attempt is made to write to the protected pages in 
memory, the presence of the translation bit will cause an exception which 
when handled by the code morphing software can cause the appropriate 
translation (s) to be invalidated or removed from the translation buffer. The T 
bit can also be used to mark other target pages that translation may rely upon 
not being written. 

This may be understood by referring to Figure 3 which illustrates in block 
diagram form the general functional elements of the microprocessor which 
includes the invention. When the morph host executes a target program, it 
actually runs the translator portion of the code morphing software which 
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includes the only original untranslated host instructions which effectively run 
on the morph host. To the right in the figure is illustrated memory divided into 
a host portion including essentially the translator and the translation buffer 
and a target portion including the target instructions and data, including the 
5 target operating system. The morph host hardware begins executing the 
translator by fetching host instructions from memory and placing those 
instructions in an instruction cache. The translator instructions generate a 
fetch of the first target instructions stored in the target portion of memory. 
Carrying out a target fetch causes the integer unit to look to the official target 

10 instruction pointer register for a first address of a target instruction. The first 
address is then accessed in the translation look-aside buffer of the memory 
management unit. The memory management unit includes hardware for 
paging and provides memory mapping facilities for the TLB. Presuming that 
the TLB is correctly mapped so that it holds lookup data for the correct page of 

15 target memory, the target instruction pointer value is translated to the 

physical address of the target instruction. At this point, the condition of the 
bit (T bit) indicating whether a translation has been accomplished for the 
target instruction is detected; but the access is a read operation, and no T bit 
exception will occur. The condition of the A/N bit indicating whether the 

20 access is to memory or memory mapped I/O is also detected. Presuming the 
last mentioned bit indicates a memory location, the target instruction is 
accessed in target memory since no translation exists. The target instruction 
and subsequent target instructions are transferred as data to the morph host 
computing units and translated under control of the translator instructions 

25 stored in the instruction cache. The translator instructions utilize reordering, 
optimizing, and rescheduling techniques as though the target instruction 
affected memor}^ The resulting translation containing a sequence of host 
instructions is then stored in the translation buffer in host memory. The 
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translation is transferred directly to the translation buffer in host memory via 
the gated store buffer. Once the translation has been stored in host memory, 
the translator branches to the translation which then executes. The execution 
(and subsequent executions) will determine if the translation has made correct 
5 assumptions concerning exceptions and memory. Prior to executing the 

translation, the T bit for the target page(s) containing the target instructions 
that have been translated is set. This indication warns that the instruction 
has been translated; and, if an attempt to write to the target address occurs, 
the attempt generates an exception which causes the translation to possibly be 
10 invalidated or removed. 

If a write is attempted to target pages marked by a T bit, an exception occurs 
and the write is aborted. The write will be allowed to continue after the 
response to the exception assures that translations associated with the target 
memory address to be written are either marked as invalid or otherwise 

15 protected against use until they have been appropriately updated. Some write 
operations will actually require nothing to be done since no valid translations 
will be affected. Other write operations will require that one or more 
translations associated with the addressed target memory be appropriately 
marked or removed. Figure 1 1 illustrates one embodiment of a translation 

20 look-aside buffer including storage positions with each entry for holding a T bit 
indication. 

An additional hardware enhancement to the morph host is a circuit utilized to 
allow data which is normally stored in memory but is used quite often in the 
execution of an operation to be replicated (or "aliased") in an execution unit 
25 register in order to eliminate the time required to fetch the data from or store 
the data to memory. For example, if data in memory is reused frequently 
during the execution of a code sequence, the data must typically be retrieved 
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from memory and loaded to a register in an execution unit each time the data 
is used< To reduce the time required by such frequent memory accesses, the 
data may instead be loaded once from memory to an execution unit register at 
the beginning of the code sequence and the register designated to function in 
place of the memory space during the period in which the code sequence 
continues. Once this has been accomplished, each of the load operations 
which would normally involve loading data to a register from the designated 
memory address becomes instead a simple register-to-register copy operation 
which proceeds at a much faster pace; and even those copy operations may 
frequently be eliminated by further optimization. 

Similarly, execution of a code sequence often requires that data be written to a 
memory address frequently during the execution of a code sequence. To 
reduce the time required by such frequent memory stores to the same address, 
each time the data is to be written to the memory address, it may be 
transferred to an execution unit register which is designated to function in 
place of the memory space during the period in which the code sequence is 
continuing. Once an execution unit register has been designated, each change 
to the data requires only a simple register-to-register transfer operation which 
proceeds much faster than storing to a memory address. 

The improved microprocessor provides a unique arrangement to accomplish 
these aliasing operations. In one embodiment illustrated in Figure 10, the 
morph host is designed to respond to a "load and protect" command with 
respect to a designated memory address which is to be used frequently in a 
code sequence. The morph host allocates a working register 111 in an 
execution unit 110 to hold the memory data and stores the memory address in 
a special register 1 12 of the memory control unit. The working register 1 1 1 
may be one of a number of registers (e.g., eight of the working registers 
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illustrated in Figure 4) in an execution unit which may be allocated for such a 
purpose. 

When memory aliasing is used to eliminate loads from a memory address to 
the execution unit, the data at the memory address is first loaded to the 
register 111 and the memory address placed in the register 112. Thereafter, 
the code sequence is executed at an accelerated rate using the data in the 
register 1 II. During this period, each operation which would normally require 
a load from the memory address held in the register 1 1 2 is accomplished 
instead by copying the data from the register 111. This continues until the 
code sequence is complete (or terminates in some other manner) and the 
protection of the memory space is removed. 

Similarly, in order to accelerate a code sequence which constantly stores data 
from an execution unit 1 10 to the same memory address, a similar aliasing 
process may be practiced. A "load and protect" command causes the memory 
address to be placed in the register 112 and the data which would normally be 
stored at that memory address to be transferred instead to the working register 

111. For example, in a computation in which a loop execution would normally 
be storing a series of values to the same memory address, by allocating a 
register 1 1 1 to hold the data and holding the memory address in a register 

1 12, the process of storing becomes a register-to-register transfer within the 
execution unit. This operation also continues until the code sequence is 
complete (or terminates in some other manner), the memory space is updated, 
and the protection of the memory space is removed. 

Although each of these aliasing techniques greatly enhances the speed of 
execution of some code sequences, these operations by which memory 
accesses are eliminated give rise to a significant number of problems. This 
especially true where a substantial portion of the host processor operations 
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relate to translation of instructions between a target instruction set and the 
host instruction set. All of these problems are related to the necessity to 
assure that data which is to be used in the execution of an instruction is valid 
at the time it is to be used. 

There are a number of instances in which data stored at a memory address 
and data stored in an execution unit register may differ so that one or the 
other is invalid at any particular instant. For example, if a working register 
1 1 1 is being used to hold data which would normally be loaded frequendy from 
the memory space to registers during a code sequence, an instruction may 
write to the memory address before the code sequence using the data in the 
execution unit register completes. In such a case, the data in the execution 
unit register being utilized by the code sequence will be stale and must be 
updated. 

As another example, if a working register is being used to hold data which 
would normally be stored frequently to a memory address during a code 
sequence, an instruction may attempt to write to the memory address before 
the code sequence using the execution unit register in place of memory 
completes. If the host processor is functioning in a mode in which data at the 
memory address is normally updated only at the end of the code sequence (a 
write-back mode), the data in the execution unit register will be stale and must 
be updated from data written to the memory address. Of course, if the host 
processor is functioning in a mode in which data at the memory address is 
normally updated each time it is written to the execution unit register (a write 
through mode), then the register and memory will be consistent. 

As yet another example, if a working register is being used to hold data which 
would normally be stored frequently during a code sequence to a memory 
address, an instruction may attempt to read data from the memory address 
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before the code sequence transferring data to the register 111 completes. If 
the host processor is functioning in a mode in which data at the memory 
address is normally updated only at the end of the code sequence (a write-back 
mode), the data in memory will be stale and must be updated by data from the 
execution unit register before the read is allowed. As with the example above, 
if the host processor is functioning in a mode in which data at the memory 
address is normally updated each time it is written to the execution \init 
register (a write through mode), then the register and memory will be 
consistent. 

Another possibility by which data held in memory and in aliasing registers may 
become inconsistent exists because the microprocessor formed by the 
combination of the morph host and the code morphing software is adapted to 
reorder and reschedule host instructions to accelerate execution. As will be 
seen in the various examples of code sequences provided below, once memory 
data has been aliased in an execution unit register to be used in the execution 
of a code sequence, the data in the execution unit register may be copied to 
other registers and a process of reordering and rescheduling instructions may 
then occur. If reordering and rescheduling has occurred, it is possible for an 
instruction in the code sequence to write to the memory address which is being 
aliased so that the data in the execution unit register must be updated before 
further use. However, if the now-stale data in the execution unit register 1 1 1 
has already been copied to additional registers and the code sequence of 
instructions using those registers has been altered, then stale data in registers 
to which the data has been copied may be utilized in carrying out the code 
sequence. Thus, a second order inconsistency may occur. 

To make sure that loads from and stores to the memory address which is being 
protected do not take place without verifying that the data at the memory 
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address and in the register 111 are consistent after the load or store operation, 
a comparator 1 13 in the memory control unit is associated with the address 
register 112. The comparator 1 13 receives the addresses of loads from 
memory and stores to the gated store buffer directed to memory during 
5 translations. If a memory address for either a load or a store compares with 
an address in the register 112 (or additional registers depending on the 
implementation), an exception may be generated depending on the mode. The 
code morphing software responds to the exception by assuring that the 
memory address and the execution unit register 1 1 1 hold the same correct 
10 data. This allows the inconsistencies described above to be corrected. 

The manner in which the code morphing software responds depends on the 
particular exception. If the data are not the same, in one embodiment, the 
translation is rolled back and reexecuted without any "aliased" data in an 
execution unit register. Such a solution allows the correction of 

15 inconsistencies which occur both between memory and the execution unit 
register and between memory and other registers which have copied the data 
from the execution unit register 1 1 1 before the code sequence was reordered or 
rescheduled. Other possible methods of correcting the problem are to update 
the execution unit register with the latest memory data or memory with the 

20 latest load data. 

During the period in which a memory address is aliased to eliminate loads 
from that memory address, the comparator looks for attempts to write the 
memory address since the data in the execution unit register 111 may become 
stale when the new data is written to the memory address. In such a case, the 
25 comparator 113 detects the attempt to write to the protected memory address; 
and generates an exception if such an attempt occurs. The exception either 
causes the data in memory to be written to the register 1 1 1 to update the 
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register before the register data may be used further, or causes a rollback and 
execution of code that does not use an execution unit register to accomplish 
alias optimization. This may involve re-translation of the target code. 

During the period in which a memory address is aliased to allow sequential 
5 store operations using a register 1 1 1 to represent the memory address, the 
generation of an exception for a store to the memory address may be disabled 
by a command which places the circuitry in a mode (write through mode) in 
which stores to the memory address from the register 111 may occur without 
an alias check thereby allowing the repetitive storage to memory at the 
10 protected address from the register. 

Alternatively, during a period in which a memory address is aliased to allow 
store operations using a register 1 1 1 to represent the memory address, the 
circuitry may be placed in a mode (write back mode) in which the data at the 
memory location is not updated until the code sequence has been completed or 

15 otherwise terminated. In such a mode, a write by an instruction to the 

memory address may require that the data held in the execution unit register 
be updated to be consistent with the new data. On the other hand, in such a 
mode, an attempt to read the memory address will require that an exception be 
generated so that the data held in the memory space can be updated to be 

20 consistent with the new data in the execution unit register before it is read. 

Figure 12 illustrates alias circuitry including one embodiment of a comparator 
120 for detecting and controlling load and store operations to protected 
memory space. The comparator 120 includes a plurality of storage locations 
122 (only one of which is illustrated) such as content addressable memory for 
25 entries of memory addresses which are to be protected. For example, there 
may be eight locations for entries. Each entry includes a sufficient number of 
bit positions (e.g., 32) to store a physical address for the memory location, a 
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byte mask, and various attribute bits. Among the attribute bits are those 
indicating the size of the protected memory and whether the memory address 
is normal or abnormal. It should be noted that the locations for entries in the 
comparator 120 are each equivalent to a register 1 12 shown in Figure 10 so 
that the comparator 120 accomplishes the purpose of both register 112 and 
comparator 1 13 of Figure 10. 

The alias circuitry also includes an alias enable register 124, a register 125 for 
shadowing the alias enable register, an alias fault register 126, a register 127 
storing an indication (e.g., a single bit) that the alias circuitry is enabled, and a 
register 128 storing a mode bit. 

In operation, a physical address to be protected is stored in one of the 
locations for entries together with a byte mask the bits of which indicate which 
bytes of the location are protected. Such a physical address may address 64 
bits of data so that each bit of the byte mask indicates one byte of the data at 
the address. The particular entry which is protected is indicated by setting a 
particular bit of the hardware enable register 124. The register 125 shadows 
the values in the register 124 at commit points during translation to allow 
rollbacks to occur during translation. In the embodiment shown, the enable 
register 24 and the shadow enable register are physically distributed as 
attribute bits of the storage locations 122. 

When aliasing is enabled as indicated by the register 127, depending on the 
condition in which the mode is set as indicated by the register 128, the 
comparator holds a physical memory address and byte mask and uses those to 
test addresses of stores to memory or both loads and stores. If the mode is set 
to a write through condition, then memory is continually updated from the 
execution unit register holding data for the protected memory address so that 
loads from that memory address to other addresses are always up to date and 
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need not be checked. However, stores to the memory address may invalidate 
the data in the execution unit register 1 12 so these stores must be tested. If a 
store is to a protected address and its byte mask shows that data is being 
stored to a protected byte at the memory address held in the comparator 120, 
5 then the comparator generates an alias exception in order to test stores in the 
write through mode. 

On the other hand, if the mode is set to a write back condition, then the 
memory address is only updated when the alias hardware is released or when 
exceptions occur. Consequently, the data at the memory address may be stale 
10 so both load and stores must be tested when the alias hardware is enabled. To 
accomplish this, if either a load or a store is to a protected address and its byte 
mask shows that data is being accessed at a protected byte at the memory 
address held in the comparator 120, then the comparator generates an alias 
exception. 

15 An exception caused in either mode sets an appropriate bit in the alias fault 
register 126 to designate the address causing the exception. Depending on the 
particular exception handler of the code morphing software, the particular 
exception generated may repair or rollback to correct the problem. A repair of 
the problem causes the most up-to-date data to be placed in the particular 

20 bytes affected of the execution unit data register and the memory address. A 
rollback causes the state of the registers to be replaced by the state held in the 
target registers; this includes the state of the enable register 124 which is 
rolled back to the state held in the register 125, 

The use of alias detection hardware to allow optimizations that eliminate loads 
25 and stores and also to allow the re-ordering or re- scheduling of operations 
dependent upon the eliminated loads and stores has been described. The re- 
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ordering enables better scheduling of operations in a machine with parallel 
execution resources, such as a superscalar or VLIW machine. 

The method can also be used to allow the safe re-ordering of operations 
dependent upon loads or stores, without eliminating the load or store 
operations. This improves scheduling performance and is useful for code 
where there is no repetition of load or store operations. 

It will be recognized by those skilled in the art that the microprocessor may be 
connected in circuit with typical computer elements to form a computer such 
as that illustrated in Figure 9. As may be seen, when used in a modern X86 
computer the microprocessor is joined by a processor bus to memory and bus 
control circuitry. The memory and bus control circuitry is arranged to provide 
access to main memory as well as to cache memory which may be utilized with 
the microprocessor. The memory and bus control circuitry also provides 
access to a bus such as a PCI or other local bus through which I/O devices 
may be accessed. The particular computer system vnll depend upon the 
circuitry utilized with a typical microprocessor which the present 
microprocessor replaces. 

In order to illustrate the operation of the processor and the manner in which 
acceleration of execution occurs, the translation of a small sample of X86 
target code to host primitive instructions is presented at this point. The 
sample illustrates the translation of X86 target instructions to morph host 
instructions including various exemplary steps of optimizing, reordering, and 
rescheduling by the microprocessor which includes the invention. By following 
the process illustrated, the substantial difference between the operations 
required to execute the original instructions using the target processor and the 
operations required to execute the translation on the host processor will 
become apparent to those skilled in the art. 
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The original instruction illustrated in C language source code describes a very 
brief loop operation. Essentially, while some variable "n" which is being 
decremented after each loop remains greater than **0", a value "c" is stored at 
an address indicated by a pointer ***s'' which is being incremented after each 
loop. 

Oriiginal C code 

while ( (n--)>0) { 
*s-*-+=c 

} 



Win32 x86 instructions produced by a compiler compiling this C code. 



mov 


%ecx, [%ebp+Oxc) 


// 


load c from memory address into the 


%ecx 


mov 


%eax, [%ebp+0x8] 


// 


load s from memory address into the 


%eax 


mov 


[%eax] , %ecx 


// 


store c into memory address s held in %eax 


add 


%eax, #4 


// 


increment s by 4 . 




mov 


t%ebp+0x8] , %eax 


// 


store (s + 4) back into memory 




mov 


%eax, [%ebp+OxlO] 


// 


load n from memory address into the 


%eax 


lea 


%ecx, [%eax-l] 


// 


decrement n and store the result in 


%ecx 


mov 


[%ebp+OxlO] , %ecx 


// 


store (n-1) into memory 




and 


%eax, %eax 


// 


test n to set the condition codes 




jg 


. -Oxlb 


// 


branch to the top of this section if 


"n>0" 



Notation: [.„] indicates an address expression for a memory operand. In the 
example above, the address for a memory operand is formed from the contents 
of a register added to a hexadecimal constant indicated by the Ox prefix. 
Target registers are indicated with the % prefix, e.g. %ecx is the ecx 
register. The destination of an operation is to the left. 

Target instruction key: 

jg = jump if greater 
mov = move 

lea = load effective address 
and = AND 

In this first portion of the sample, each of the individual X86 assembly 
language instructions for carrying out the execution of the operation defined 
by the C language statement is listed by the assembly language mnemonic for 
the operation followed by the parameters involved in the particular primitive 
operation. An explanation of the operation is also provided in a comment for 



each instruction. Even though the order of execution may be varied by the 
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target processor from that shown, each of these assembly language 
instructions must be executed each time the loop is executed in carrying out 
the target C language instructions. Thus, if the loop is executed one hundred 
times, each instruction shown above must be carried out one hundred times. 

Shows each X86 Instruction shown above followed by the host Instructions necessary to 
Implement the X86 Instruction. 





mov 


r 

%0cx, [%ebp+Oxc] 


// load c from memory address into ecx 


10 


add 
Id 


RO , Rebp , Oxc 
Recx, fROl 


; form the memory address and put it in RO 
; load c from memory address in RO into Recx 




mov 


%eax, [%ebp+0x8] 


// load s from memory address into %eax 


15 


add 
Id 


R2 ,Rebp, 0x8 
Reax, tR2] 


; form the memory address and put it in R2 
; load s from memory address in R2 into Recx 




mov 


[%eax], %ecx 


// store c into memory address s held in %eax 


20 


St 


[Reax] ,Recx 


; store c into memory address s held in Reax 




add 




// increment s by 4 


25 


add 


Reax, Reax, 4 


; increment S by 4 


mov 


[%ebp+0x8], %eax 


// store (s + 4) back into memory 


30 


add 

St 


R5 , Rebp, 0x8 
[R5] , Reax 


; form the memory address and put it in R5 
; Store {s + 4) back into memory 


mov 


%eax, [%ebp+0x10] 


// load n from memory address into %eax 


35 


add 
Id 


R7,Rebp, 0x10 
Reax, [R7] 


; form the memory address and put it in R7 
; load n from memory address into the Reax 


lea 


%ecx. [%eax-1] 


// decrement n and store the result in %ecx 




sub 


Recx, Reax, l 


; decrement n and store the result in Recx 


40 


mov 


[7oebp+0x10], %ecx 


// store (n - 1) into memory 




add 


R9 , Rebp, 0x10 


; form the memory address and put it in R9 


45 


St 


[R9J , Recx 


; store {n - 1) into memory 


and 


%eax, %eax 


// test n to set the condition codes 




andcc 


Rll, Reax, Reax 


; test n to set the condition codes 



63 



PCT/US97/22768 



jg .-Ojtib // branch to the top of this section if "n>0" 

jg mainloop,mainloop ; jump to the main loop 

Host Instruction key: 

Id = load add = ADD st =store 

sub = subtract jg = jump if condition codes indicate greater 

andcc = and set the condition codes 



10 The next sample illustrates the same target primitive instructions which cany 
out the C language instructions. However, following each primitive target 
instruction are listed primitive host instructions required to accomplish the 
same operation in one particular embodiment of the microprocessor in which 
the morph host is a VLIW processor designed in the manner described herein. 

15 It should be noted that the host registers which are shadowed by official target 
registers are designated by an "R" followed by the X86 register designation so 
that, for example, Reax is the working register associated with the EAX official 
target register. 

Adds host instructions necessary to perform X86 address computation and upper and lower 
20 segment limit checks. 

// load c 

; form logical address into RO 
Check the logical address against segment lower 

Check the logical address against segment upper 
; add the segment base to form the linear 
; load c from memory address in Rl into Recx 
// load s 

; form logical address into RO 
Check the logical address against segment lower 

Check the logical address against segment upper 

; add the segment base to form the linear 

; load s from memory address in R3 into Ra 



mov %ecx, [%ebp+Oxc] 

add RO,Rebp,0xc 

25 chkl RO,Rss_limit 
limit 

chku RO , R_FFFFFFFF 
limit 

add R1,R0, Rs Sybase 
30 address 

Id Recx, [Rl] 

mov %eax, [%ebp+0x8] 

35 add R2,Rebp,0x8 

chkl R2,Rss_limit 
limit 

chku R2 , R_FFFFFFFF 
limit 

40 add R3,R2,Rss_base 
address 

Id Reax, tR3] 
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mov [%eax], %ecx 

chJcu Reax,Rds_limit 
limit 

add R4 , Reax , Rds_base 
address 

St [R4] ,Recx 

add %ea}t, M 

addcc Reax, Reax, 4 

mov E%ebp+0x8]. %eax 

add R5 , Rebp , 0x8 
chkl R5,Rss_limit 
limit 

Chku R5,R_PFFFFFFF 
limit 

add R6,R5, Ras_base 
address 

St [R6] ,Reax 

mov %eax, [%ebp-o-0x10] 

add R7 , Rebp , 0x1 0 
chkl R7,Rss_limit 
limit 

chku R7 , R_FFFFFFFF 
limit 

add R8,R7,Rss_base 
address 

Id Reax, [R8] 

ba %ecx, [%eax-1] 

sub Recx,Reax,l 

mov [%ebp+0x1 0], %ec)c 

add R9, Rebp, 0x10 

chkl R9,Rss_limit ; 

limit 

chku R9,R__FFFFFFFF 
limit 

add RIO , R9 , Rss_base 
address 

St tR10],Recx 
in RIO 

and %Gax, %eax 

andcc Rll , Reax, Reax 



64 

// store c into [s] 
Check the logical address against segment upper 
; add the segment base to form the linear 
; store c into memory address s 

// increment s by 4 
; increment s by 4 

// store (s + 4) to memory 

; form logical address into R5 
Check the logical address against segment lower 

Check the logical address against segment upper 

; add the segment base to form the linear 

; store (s + 4) to memory address in R6 

// load n 

; form logical address into R7 
Check the logical address against segment lower 

Check the logical address against segment upper 
; add the segment base to form the linear 
; load n from memory address in R8 into Reax 
// decrement n 

; decrement n 
// store (n - 1) 

; form logical address into R9 
Check the logical address against segment lower 

Check the logical address against segment upper 

; add the segment base to form the linear 

; store n-i in Recx into memory using address 

// test n to set the condition codes 

; test n to set the condition codes 
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jg .-0x1 b 

jg niainloop,mainloop 

Ho6t Instruction key: 

chkl + check lower limit 
chku « check upper limit 



65 

// branch to the top of this section if "n>0" 
; jump to the main loop 



The next sample illustrates for each of the primitive target instructions the 
10 addition of host primitive instructions by which addresses needed for the 
target operation may be generated by the code morphing software. It should 
be noted that host address generation instructions are only required in an 
embodiment of a microprocessor in which code morphing software is used for 
address generation rather than address generation hardware. In a target 
15 processor such as an X86 microprocessor these addresses are generated using 
address generation hardware. Whenever address generation occurs in such an 
embodiment, the calculation is accomplished; and host primitive instructions 
are also added to check the address values to determine that the calculated 
addresses are within the appropriate X86 segment limits. 

20 Adds instructions to maintain the target X86 instruction pointer "elp" and 

the commit instructions that use the special morph host hardware to update X86 state. 

mov %ecx, [%3bp+0xcl // load c 

25 add RO,Rebp,Oxc 

chkl RO,Rss_limit 

chku R 0 , R_FFFFFFFF 

add Rl,RO,Rss_base 

Id Recx, [Rl3 

30 add Reip,Reip,3 ; add X86 instruction length to eip in 

Reip 

commit ; commits working state to official state 



35 



mov %eax, [%ebp+0x81 // load s 



add R2,Rebp,0x8 

chkl R2,Rss_limit 

chku R2 , R_FFFFFFFF 

add R3, R2 , Rss_base 

40 Id Reax, [R3] 

add Reip, Reip, 3 ; add X86 instruction length to eip in 

Reip 
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10 



15 



20 



25 



35 



40 



45 



50 



55 



commit 

mov [%eax], %ecx 

chku Reax , Rde_l imi t 

add R4 , Reax, Rds^base 

St [R4] , Recx 

add Reip,Reip,2 

Reip 

commit 

add %eax, #4 

addcc Reax , Reax , 4 
add Reip, Reip, 5 
Reip 
commit 

mov [%ebp+0x8], %eax 



add 
chkl 
chku 
add 

St 

add 
Reip 
commit 



R5, Rebp, 0x8 
R5, Rss_limit 
R5 , R_FFFFPFFF 
R6,R5,Rss_base 
[R6] ,Reax 
Reip, Reip, 3 



30 mov %eax, [%ebp+0x10] 



add 
chkl 
chku 
add 
Id 
add 
Reip 
commit 



R7,Rebp, 0x10 
R7,Rss_limit 
R7 , R__FFFFFFFF 
R8, R7, Rs Sybase 
Reax, [R8] 
Reip, Reip, 3 



lea %ecx, [%eax-1] 

sub Recx, Reax, 1 

add Reip, Reip, 3 
Reip 
commit 

mov [%ebp+0x10], %ecx 

add R9, Rebp, 0x10 

chkl R9,Rss_limit 

chku R9 , R_FFFFFFFF 

add R10,R9,Rss_base 

St [RIO], Recx 

add Reip, Reip, 3 



; commits working state to official state 
// store c into [s] 

; add X86 instruction length to eip in 
; commits working state to official state 
// increment s by 4 

; add X86 instruction length to eip in 
; commits working state to official state 

// store (s + 4) 



; add X86 instruction length to eip in 
; commits working state to official state 
// load n 



; add X86 instruction length to eip in 
; commits working state to official state 
/ / decrement n 

; add xee instruction length to eip in 
; commits working state to official state 
// store (n - 1) 



add X86 instruction length to eip in 
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Reip 



commit 



commits 



working state to official state 



and Voeax, %ea;t 



// test n 



andcc Rll, Reax, Reax 
add ReipiReip,3 
commit 



commits 



working state to official state 



jg 



.-0x1 b 



// branch 



"n>0" 



add Rseq, Reip, Length (jg) 
Idc Rtarg , EIP ( target ) 
selcc Reip, Rseq, Rtarg 
commit 

jg mainloop, mainloop 



commi t s 



working state to official state 



Host Instruction key: 

commit « copy the contents of the working registers to the official 
target registers and send working stores to memory 

This sample illustrates tKe addition of two steps to each set of primitive host 
instructions to update the official target registers after the execution of the 
host instructions necessary to carry out each primitive target instruction and 
to commit the uncommitted values in the gated store buffer to memory. As 
may be seen, in each case, the length of the target instruction is added to the 
value in the working instruction pointer register (Reip). Then a commit 
instruction is executed. In one embodiment, the commit instruction copies the 
current value of each working register which is shadowed into its associated 
official target register and moves a pointer value designating the position of the 
gate of the gated store buffer from immediately in front of the uncommitted 
stores to immediately behind those stores so that they will be placed in 
memory. 

It will be appreciated that the list of instructions illustrated last above are all of 
the instructions necessary to form a host translation of the original target 
assembly language instructions. If the translation were to stop at this point, 
the number of primitive host instructions would be much larger than the 
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number of target instructions (probably six times as many instructions), and 
the execution could take longer than execution on a target processor. 
However, at this point, no reordering, optimizing, or rescheduling has yet 
taken place. 

If an instruction is to be run but once, it may be that the time required to 
accomplish further reordering and other optimization is greater than the time 
to execute the translation as it exists at this point. If so, one embodiment of 
the microprocessor ceases the translation at this point, stores the translation, 
then executes it to determine whether exception or errors occur. In this 
embodiment, steps of reordering and other optimization only occur if it is 
determined that the particular translation will be run a number times or 
otherwise should be optimized. This may be accomplished, for example by 
placing host instructions in each translation which count the number of times 
a translation is executed and generate an exception (or branch) when a certain 
value is reached. The exception (or branch) transfers the operation to the code 
morphing software which then implements some or all of the following 
optimizations and any additional optimizations determined useful for that 
translation. A second method of determining translations being run a number 
of times and requiring optimization is to interrupt the execution of translations 
at some frequency or on some statistical basis and optimize any translation 
running at that time. This would ultimately provide that the instructions most 
often run would be optimized. Another solution would be to optimize each of 
certain particular types of host instructions such as those which create loops 
or are otherwise likely to be run most often. 
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Optimization 



Assumes 32 bit flat address space which allows the elimination of segment base additions and 
some limit checks. 



10 



15 



Win32 uses Flat 32b segmentation 

Record Assumptions: 
Rss^base—O 
RssJimit=-0 
Rds_base-=^0 
Rd$Jimit=^FFFFFFFF 
SS and DS protection check 



20 



25 



30 



35 



mov %ecx,[%ebp+Oxc] 

add RO,Rebp,Oxc 
Chlcu RO , R_FFFPFFFF 
Id Recx, [RO] 
add Reip,Reip,3 
commit 

mov %eax,[7oebp+0x81 

add R2 , Rebp , 0x8 
chku R2 , R_FFFFFFFF 
Id Reax, [R23 
add Reip , Reip , 3 
commit 

mov [%eax],%ecx 

chku Reax , R_FFFFFFFF 
St [Reax] , Recx 
add Reip, Reip, 2 
commit 



// load c 



// load s 



// store c into [s] 



40 



45 



50 



add %eax,#4 

addcc Reax, Reax, 4 
add Reip, Reip, 5 
commit 

mov [%ebp+0x8],%eax 

add R 5, Rebp, 0x8 
chku R5 , R_FPFFPFFF 
St [R5],Reax 
add Reip, Reip, 3 
commit 



// increment s by 4 



// store (s + 4) 
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mov %eax,[%ebp+0x1 0] 

add R7 , Rebp , 0x10 
Chku R7 , R^FFFFFFFF 
5 Id Reax, [R7] 
add Reip,Reip,3 
conunit 

lea %ecx,[%eax-1] 

10 

sub Recx , Reax , 1 
add Reip,Reip,3 
commi t 

15 mov I%ebp+0jc10],%ecx 

add R9, Rebp, 0x10 
chku R9 , R_FFFFFFFF 
St [R9] ,Recx 
20 add Reip,Reip,3 
commit 

and 7oeax,%eax 

25 andcc Rll , Reax, Reax 
add Reip,Reip,3 
commit 

jg .-0x1 b 

30 

add Rseq, Reip, Length (jg) 
Idc Rcarg , EIP ( target ) 
selcc Reip, Rseq, Rtarg 
commit 

35 jg mainloop , mainloop 



This sample illustrates a first stage of optimization which may be practiced 
utilizing the improved microprocessor. This stage of optimization, like many of 
the other operations of the code morphing software, assumes an optimistic 
40 result. The particular optimization assumes that a target appUcation program 
which has begun as a 32 bit program written for a flat memory model provided 
by the X86 family of processors will continue as such a program. It will be 
noted that such an assumption is particular to the X86 family and would not 
necessarily be assumed with otiier families of processors being emulated. 



70 

// load n 



// decrement n 



// store (n - 1) 



// test n 



// branch "n>0" 
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If this assumption is made, then in X86 applications all segments are mapped 
to the same address space. This allows those primitive host instructions 
required by the X86 segmentation process to be eliminated. As may be seen, 
the segment values arc first set to zero. Then, the base for data is set to zero, 
and the limit set to the maximum available memory. Then, in each set of 
primitive host instructions for executing a target primitive instruction, the 
check for a segment base value and the computation of the segment base 
address required by segmentation are both eliminated. This reduces the loop 
to be executed by two host primitive instructions for each target primitive 
instruction requiring an addressing function. At this point, the host 
instruction check for the upper memory limit still exists. 

It should be noted that this optimization requires the speculation noted that 
the application utilizes a 32 bit flat memory model. If this is not true, then the 
error will be discovered as the main loop resolves the destination of control 
transfers and detects that the source assumptions do not match the 
destination assumptions. A new translation will then be necessary. This 
technique is very general and can be applied to a variety of segmentation and 
other "moded" cases where the "mode" changes infrequently, like debug, 
system management mode, or "real" mode. 

Assume data addressed includes no bytes outside of computer memory limits which can only 
occur on unaligned page crossing memory references at the upper memory limit, and can be 
handled by special case software or hardware. 



mov %ecx, [%ebp+Oxc] 



// load c 



add RO,Rebp,Oxc 
Id Recx, [RO] 
add Reip,Reip,3 
commit 



mov 



%eax. [%ebp+0x8] 



// load s 



add 
Id 



R2 , Rebp, 0x8 
Reax, [R2] 
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add Reip , Reip , 3 
commit 
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mOV [%eax], %eCX // store c into [s] 

5 

St [Reax] ,Recx 
add Reip, Reip, 2 
commit 

10 add %eax, #4 // increment s by 4 

addcc Reax, Reax, 4 
add Reip , Reip , 5 
commit 

15 

mov [%ebp+0x8], %eax // store is + 4) 

add R5 , Rebp , 0x8 
St (R5] ,Reax 
20 add Reip, Reip, 3 
commi t 



mov %eax, [%ebp+0x10l // load n 

25 add R7, Rebp, 0x10 
Id Reax, [R73 
add Reip, Reip, 3 
commit 



30 lea %ecx, [7oeaX-1] // decrement n 

sub Recx,Reax,l 
add Reip, Reip, 3 
commit 

35 

mov [%ebp+0x10], %eCX // store (n - 1) 

add R9, Rebp, 0x10 
St [R9] ,Recx 
40 add Reip, Reip, 3 
commit 



and yoeax, %eax // test n 

45 andcc Rll , Reax, Reax 
add Reip, Reip, 3 
commi t 



jg .-Ox1b // branch *'n>0" 

50 

add Rseq, Reip, Length (jg) 
Idc Rtarg,EIP (target) 
selcc Reip, Rseq, Rtarg 
commit 

55 jg mainloop, mainloop 
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Host Instruction key: 

selcc = Select one of the source registers and copy its contents to the 
destination register based on the condition codes . 



The above sample illustrates a next stage of optimization in which a 
speculative translation eliminates the upper memory boundary check which is 
only necessary for unaligned page crossing memory references at the top of the 
memory address space. Failure of this assumption is detected by either 

10 hardware or software alignment fix up. This reduces the translation by 
another host primitive instruction for each target primitive instruction 
requiring addressing. This optimization requires both the assumption noted 
before that the application utilizes a 32 bit flat memory model and the 
speculation that the instruction is aligned. If these are not both true, then the 

15 translation will fail when it is executed; and a new translation will be 
necessary. 

Detect and eliminate redundant address calcijlations. The example shows the code after 
eliminating the redundant operations. 

20 mov %ecx, [%ebp+Oxc] // load c 

add R0,Rebp,Oxc 
Id Recx. [RO] 
add Reip,Reip,3 
25 commit 



5 



mov 



%eax. [%ebp+0x8] 



// load s 



30 



add R2,Rebp,0xB 
Id Reax, tR2] 
add Reip,Reip,3 
commit 



mov [7oeax], %ecx 



// store c into [s] 



35 



St 

add 
commit 



[Reax] , Recx 
Reip, Reip, 2 
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add %eax, #4 // increment s by 4 

addcc Reax , Reax , 4 
add Reip,Reip,5 
5 commit 

mov [%ebp+0x8], %eax // store (s + 4) 

St [R2] , Reax 
to add Reip,Reip,3 
commit 

mov %eax, [%ebp+0x10] // load n 

15 add R7,Rebp,0xl0 
Id Reax, [R7] 
add Reip,Reip,3 
commit 

20 iea %eCX, [%eaX-1] // decrement n 

sub Recx,Reax,l 
add Reip,Reip,3 
commit 

25 

mov [%ebp+0x10], %eCX // store (n - l) 

St [R7] ,Recx 
add Reip,Reip,3 
30 commit 

and %eax,%eax // test n 

andcc Rll , Reax, Reax 
35 add Reip,Reip,3 
commit 

jg .-0x1 b // branch '•n>0" 

40 add Rseq, Reip, Length (jg) 
Idc Rtarg, EIP (target) 
selcc Reip,Rseq,Rtarg 
commit 

jg mainloop,mainloop 

45 



This sample illustrates a next optimization in which common host expressions 
are eliminated. More particularly, in translating the second target primitive 
instruction, a value in working register Rebp (the working register representing 
the stack base point register of an X86 processor) is added to an offset value 
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0x8 and placed in a host working register R2. It will be noted that the same 
operation took place in translating target primitive instruction five in the 
previous sample except that the result of the addition was placed in working 
register R5. Consequently the value to be placed in working register R5 
already exists in working register R2 when host primitive instruction five is 
about to occur. Thus, the host addition instruction may be eliminated from 
the translation of target primitive instruction five; and the value in working 
register R2 copied to working register R5. Similarly, a host instruction adding 
a value in working register Rebp to an offset value 0x10 may be eliminated in 
the translation of target primitive instruction eight because the step has 
already been accomplished in the translation of target primitive instruction six 
and the result resides in register R7. It should be noted that this optimization 
does not depend on speculation and consequently is not subject to failure and 
re translation. 



target state. 






mov 


%ecx,[%ebp+Oxc] 


If 


load c 


add 
Id 


RO , Rebp, Oxc 
Recx, [RO] 






mov 


7oeax,[%ebp^0x8] 


// 


load s 


add 
Id 


R2 , Rebp , 0x8 
Reax, [R2] 






mov 


[%eax],%ecx 


II 


store c into [s] 


St 


[Reax] ,Recx 






add 


%eax,#4 


II 


increment s by 4 


add 


Reax, Reax, 4 






mov 


[%ebp+0x8],%eax 


II 


store {s + 4) 


sc 


[R2] , Reax 
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add Rseq, Reip , Length (block) 
Ida Rtarg,EIP (target) 
selcc Reip,Rseq,Rtarg 
commit 

jg mainloop, mainloop 
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mov 


%eax,[%ebp+0x10] 




II load n 


add 
Id 


R7, Rebp, 0x10 
Reax, [R7] 






lea 


%ecx,[%eax-1] 


/ / 


uecremenu n 


sub 


Recx , Reax , 1 






mov 


[%ebp+0x1 0],%ecx 




// store (n 


at 


[R7] ,Recx 






and 


%eax,%eax 


II 


test n 


andcc 


Rll ^ Reax, Reax 






jg 


.-0x1 b 


II 


branch "n>0" 



The above sample illustrates an optimization which speculates that the 
translation of the primitive target instructions making up the entire translation 
may be accomplished without generating an exception. If this is true, then 
there is no need to update the official target registers or to commit the 
uncommitted stores in the store buffer at the end of each sequence of host 
primitive instructions which carries out an individual target primitive 
instruction. If the speculation holds true, the official target registers need only 
be updated and the stores need only be committed once, at the end of the 
sequence of target primitive instructions. This allows the elimination of two 
primitive host instructions for carrying out each primitive target instruction. 
These are replaced by a single host primitive instruction which updates the 
official target registers and commits the uncommitted stores to memory. 

As will be understood, this is another speculative operation which is also 
highly likely to involve a correct speculation. This step offers a very great 
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advantage over all prior art emulation techniques if the speculation holds true. 
It allows all of the primitive host instructions which carry out the entire 
sequence of target primitive instructions to be grouped in a sequence in which 
all of the individual host primitives may be optimized together. This has the 
advantage of allowing a great number of operations to be run in parallel on a 
morph host which takes advantage of the very long instruction word 
techniques. It also allows a greater number of other optimizations to be made 
because more choices for such optimizations exist. Once again, however, if the 
speculation proves untrue and an exception is taken when the loop is 
executed, the official target registers and memory hold the official target state 
which existed at the beginning of the sequence of target primitive instructions 
since a commit does not occur until the sequence of host instructions is 
actually executed. All that is necessary to recover from an exception is to 
dump the uncommitted stores, rollback the official registers into the working 
registers, and restart translation of the target primitive instructions at the 
beginning of the sequence. This re- translation produces a translation of one 
target instruction at a time, and the official state is updated after the host 
sequence representing each target primitive instruction has been translated. 
This translation is then executed. When the exception occurs on this re- 
translation, correct target state is immediately available in the official target 
registers and memory for carrying out the exception. 
In summary: 

add RO,Rebp,Oxc 
Id Recx, [RO] 
add R2,Rebp,0x8 
Id Reax, [R21 
St [Reax] ,Recx 
add Reax, Reax, 4 
St [R2] , Reax 
add R7,Rebp,0xl0 

Id Reax, (R7] // Live out 

sub Recx, Reax, 1 // Live out 

St [R7],Recx 
andcc Rl l , Reax , Reax 



wo 98/28689 



PCT/US97/22768 



78 



add Rseq, Reip, Length (block) 
Idc Rtarg^EIP (target) 
selcc Reip, Rseq, Rtarg 



5 



commit 

jg mainloop, mainloop 



The comment "Live Out" refers to the need to actually maintain Reax and Recx 
correctly prior to the commit. Otherwise further optimization might be 
10 possible. 



The summary above illustrates the sequence of host primitive instructions 
which remain at this point in the optimization process. While this example 
15 shovi^s the maintenance of the target instruction pointer (EIP) inline, it is 
possible to maintain the pointer EIP for branches out of line at translation 
time, which would remove the pointer EIP updating sequence from this and 
subsequent steps of the example. 

Renaming to reduce register resource dependencies. This will allow subsequent scheduling to be 
20 more effective. From this point on. the original target X86 code is omitted as the relationship 

between individual target X86 instructions and host instructions becomes increasingly blurred. 




35 



25 



30 



add RO,Rebp,Oxc 

Id Rl, [RO] 

add R2,Rebp,0x8 

Id R3, [R23 

St [R3],R1 

add R4 , R3 , 4 

St [R21.R4 

add R7,Rebp,0xl0 

Id Reax, [R7] 

sub Recx, Reax, 1 

St [R7l ,Recx 

andcc Rll , Reax, Rcax 

add Rseq, Reip, Length (block) 

Idc Rtarg , EIP (target ) 

selcc Reip. Rseq, Rtarg 

commit 

jg mainloop, mainloop 



/ / Live out 
/ / Live out 



40 



This sample illustrates a next step of optimization, normally called register 
renaming, in which operations requiring working registers used for more than 
one operation in the sequence of host primitive instructions are changed to 
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Utilize a different unused working register to eliminate the possibility that two 
host instructions will require the same hardware. Thus, for example, the 
second host primitive instruction in two samples above uses working register 
Recx which represents an official target register ECX. The tenth host primitive 

5 instruction also uses the working register Recx. By changing the operation in 
the second host primitive instruction so that the value pointed to by the 
address in RO is stored in the working register Rl rather than the register 
Recx, the two host instructions do not both use the same register. Similarly, 
the fourth, fifth, and sixth host primitive instructions all utilize the working 

10 register Reax in the earlier sample; by changing the fourth host primitive 
instruction to utilize the previously unused working register R3 instead the 
working register Reax and the sixth host primitive instruction to utilize the 
previously unused working register R4 instead of the register Reax, these 
hardware dependencies are eliminated. 

15 After the scheduling process which organizes the primitive host operations as multiple 

operations that can execute in the parallel on the host VLIW hardware. Each line shows the 
parallel operations that the VLIW machine executes, and the indicates the parallelism. 



20 



25 



add 


R2, Rebp, 0x8 




add RO,Rebp, Oxc 


nop 




&. 


add R7 , Rebp , 0x1 0 


Id 


R3, [R2] 


& 


add Rseq. Reip, Length (block) 


Id 


Rl, [RO] 


& 


add R4,R3,4 


St 


[R3] ,R1 


& 


Idc Rtarg, EIP (target) 


Id 


Reax, [R7] 


& 


nop 


St 


[R2] ,R4 


£c 


sub Recx, Reax, 1 


St 


[R7) , Recx 


Sc 


andcc Rl 1 , Reax , Reax 


selcc 


Reip , Rseq , Rtarg 


Sl 


jg ma in loop, ma in loop & commit 



30 Host Instruction key: 

nop = no operation 



The above sample illustrates the scheduling of host primitive instructions for 
execution on the morph host, hi this example, the morph host is presumed to 
35 be a VLIW processor which in addition to the hardv^are enhancements 

provided for cooperating with the code morphing software also includes, among 
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Other processing units, two arithmetic and logic (ALU) units. The first line 

illustrates two individual add instructions which have been scheduled to run 

together on the morph host. As may be seen, these are the third and the eight 

primitive host instructions in the sample just before the summaiy above. The 

second line includes a NOP instruction (no operation but go to next 

instruction) and another add instruction. The NOP instruction illustrates that 

there are not always two instructions which can be run together even after 

some scheduling optimizing has taken place. In any case, this sample 

illustrates that only nine sets of primitive host instructions are left at this 

point to execute the original ten target instructions. 

Resolve host branch targets and chain stared translations 

add R2,Rebp,0x8 & add RO,Rebp,Oxc 

nop El add R7,Rebp,0xl0 

Id R3, [R2] & add Rseq, Reip, Length (block) 

Id Rl, [RO] & add R4,R3,4 

St [R5],R1 & Idc Rtarg^EIP (target) 

Id Reax, [R7] & nop 

St rR2],R4 & sub Recx,Reax,l 

St [R7],Recx & andcc Rll , Reax, Reax 

selcc Reip,Rseq,Rtarg & jg Sequential , Target & commit 



This sample illustrates essentially the same set of host primitive instructions 
except that the instructions have by now been stored in the translation buffer 
and executed one or more times because the last jump (jg) instruction now 
points to a jump address furnished by chaining to another sequence of 
translated instructions. The chaining process takes the sequence of 
instructions out of the translator main loop so that translation of the sequence 
has been completed. 

Advanced Optimizations, Backward Code Motion: 

This and subsequent examples start with the code prior to scheduling. This 
optimizacion first depends on detecting that the code is a loop. Then 
invariant operations can be moved out of the loop body and executed once 
before entering the loop body. 
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entry: 



Loop: 



add RO,Rebp,0xc 

add R2,Rebp,0x8 

add R7,Rebp,0xl0 

add Rseq , Reip, Length (block) 

Idc Rtarg , EIP ( target ) 



Id Rl, [RO] 
10 Id R3, [R2] 

St [R3] ,R1 

add R4 , R3 , 4 
St [R2] ,R4 

Id Reax, tR7] 
15 sub Recx,Reax,l 

St [R7] , Recx 
andcc Rll , Reax, Reax 
selcc Reip, Rseq, Rtarg 
commit 

20 jg mainloop, Loop 



The above sample illustrates an advanced optimization step which is usually 
only utilized with sequences which are to be repeated a large number of times. 
The process first detects translations that form loops, and reviews the 
25 individual primitives host instructions to determine which instructions 
produce constant results within the loop body. These instructions are 
removed from the loop and executed only once to place a value in a register; 
from that point on, the value stored in the register is used rather than 
rerunning the instruction. 

30 Schedule the loop body after backward code motion. For example purposes, only the 
code in the loop body is shown scheduled 

Entry: 

add RO,Rebp,Oxc 

35 add R2,Rebp,0x8 

add R7,Rebp,0xl0 

add Rseq, Reip, Length (block) 

Idc Rtarg , EIP ( target ) 



40 Loop : 



45 



Id 


R3, [R23 


& 


nop 


Id 


Rl, [RO] 


& 


add R4,R3,4 


st 


CR3} ,R1 


& 


nop 


Id 


Reax, [K7] 


£t 


nop 


St 


[R2] ,R4 


& 


sub Recx, Reax, 1 


St 


- [R7] , Recx 


& 


andcc Rll , Reax, Reax 
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selcc Reip,Rseq,Rtarg 



& jg Sequential, Loop 



& commit 



Host Instruction key: 

Idc = load a 32 -bit constant 

When these non-repetitive instructions are removed from the loop and the 
sequence is scheduled for execution, the scheduled instructions appear as in 
the last sample above. It can be seen that the initial instructions are 
performed but once during the first iteration of the loop and thereafter only the 
host primitive instructions remaining in the seven clock intervals shown are 
executed during the loop. Thus, the execution time has been reduced to seven 
instruction intervals from the ten instructions necessary to execute the 
primitive target instructions. 

As may be seen, the steps which have been removed from the loop are address 
generation steps. Thus, address generation only need be done once per loop 
invocation in the improved microprocessor; that is, the address generation 
need only be done one time. On the other hand, the address generation 
hardware of the X86 target processor must generate these addresses each time 
the loop is executed. If a loop is executed one hundred times, the improved 
microprocessor generates the addresses only once while a target processor 
would generate each address one hundred times. 
After Backward Code Motion: 
Target : 



add RO , Rebp , Oxc 

add R2,Rebp,0xB 

add R 7, Rebp, 0x10 

add Rseq, Reip, Length (block) 

Idc Rtarg, EIP (target) 



Loop : 



Id 
Id 

St 

add 

St 

Id 



Rl, [RO] 
R3, [R2] 
[R3) ,R1 
R4 ,R3, 4 
[R2] ,R4 



Reax, [R7] 



//Live out 
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sub Recx,Reax,l //Live out 

St [R7] ,Recx 

andcc Rll , Reax, Reax 

selcc Reip, Rseq, Rtarg 

commit 

jg mainloop, Loop 



Register Allocation : 

10 This shows the use of register alias detection hardware of the morph hoot 
that allows variables to be safely moved from memory into registers. The 
starting point is the code after "backward code motion" . This shows the 
optimization that can eliminate loads. 

15 First the loads are performed. The address is protected by the alias 

hardware, such that should a store to the address occur, an "alias" exception 

is raised. The loads in the loop body are then replaced with copies. After 
the main body of the loop, the alias hardware is freed. 

20 Entry : 

add R0,Rebp,Oxc 

add R2,Rebp,0x8 

add R7,Rebp,0xl0 

add Rseq,Reip,Length(block) 

25 Idc Rtarg, EIP (target) 

Id Rc, [RO] ; First do the load of the variable from memory 

prot [RO],Aliasl ;Then protect the memory location from stores 

30 Id Rs, tR2] 

prot [R2] , Alias2 



35 



Loop : 



Id Rn, [R7j 
prot [ni] , Alias3 



copy Rl , Rc 
copy R3,Rs 



St [R3],R1 
40 add R4 , Rs , 4 

copy Rs , R4 

St [R2] ,Rs,NoAliasCheck 

copy Reax,Rn //Live out 

45 sub Recx,Reax,l //Live out 

copy Rn,Recx 

st [R7] ,Rn,noAliasCheck 
andcc Ril , Reax, Reax 
selcc Reip, Rseq, Rtarg 
50 commit 

jg Epilog, Loop 

Epilog : 

FA Aliasi Free the alias detection hardware 

55 FA Alias 2 Free the alias detection hardware 

FA Alias3 Free the alias detection hardware 

j Sequential 
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Host Instruction key: 

protect = protect address from loads fa = free alias 

copy = copy j = jump 

This sample illustrates an even more advanced optimization which may be 
practiced by the microprocessor including the present invention. Referring 
back to the second sample before this sample, it will be noticed that the first 
three add instructions involved computing addresses on the stack. These 
addresses do not change during the execution of the sequence of host 
operations. Consequently, the values stored at these addresses may be 
retrieved from memory and loaded in registers where they are immediately 
available for execution. As may be seen, this is done in host primitive 
instructions sbc, eight, and ten. In instructions seven, nine and eleven, each of 
the memory addresses is marked as protected by special host alias hardware 
and the registers are indicated as aliases for those memory addresses so that 
any attempt to vary the data will cause an exception. At this point, each of the 
load operations involving moving data from these stack memory addresses 
becomes a simple register-to-register copy operation which proceeds much 
faster than loading from a memory address. It should be noted that once the 
loop has been executed until n=0, the protection must be removed from each of 
the memory addresses so that the alias registers may be otherwise utilized. 
Copy Propagation : 

After using the alias hardware to turn loads within the loop body into 
copies, copy propagation allows the elimination of some copies. 

Entry : 

add RO,Rebp,Oxc 

add R2,Rebp,0x8 

add R7,Rebp,0xlO 

add Rseq , Reip , Length (block ) 

Idc Rtarg , EIP ( target ) 

Id Rc, [RO] 
prot [RO] ,Aliasl 
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Loop : 



Epilog: 



Id Rs, [R2] 

prot [R2] , Alias2 

Id Recx, [R7] 

prot [R7) , Alias3 



St [Rs] ,Rc 
add Rs , Rs « 4 

St [R2] ,Rs,NoAliasCheck 

copy Reax,Recx //Live out 

sub Recx,Reax,l //Live out 

St [R7] ,Recx,NoAliasCheck 

andcc Rll , Reax,Reax 

selcc Reip, Rseq, Rtarg 

commit 

jg Epilog, Loop 



FA Alias 1 

FA Alias 2 

FA Aliaea 

j Sequential 



This sample illustrates the next stage of optimization in which it is recognized 
that most of the copy instructions which replaced the load instructions in the 
optimization illustrated in the last sample are unnecessary and may be 
eliminated. That is, if a register-to-register copy operation takes place, then 
the data existed before the operation in the register from which the data was 
copied. If so, the data can be accessed in the first register rather than the 
register to which it is being copied and the copy operation ehminated. As may 
be seen, this eliminates the first, second, fifth, and ninth primitive host 
instructions shown in the loop of the last sample. In addition, the registers 
used in others of the host primitive instructions are also changed to reflect the 
correct registers for the data. Thus, for example, when the first and second 
copy instructions are eliminated, the third store instruction must copy the 
data from the working register Rc where it exists (rather than register Rl) and 
place the data at the address indicated in working register Rs where the 
address exists (rather than register R3). 
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Example illustrating scheduling of the loop body only . 

Entry : 



Loop : 



Epilog : 



_ J J 

a ad 


RO,Rebp, Oxc 






add 


R2,Rebp, 0x8 






add 


R7, Rebp, 0x10 






a ad 


Rseq, Reip, Length {block) 


IQC 


Rtarg , EIP ( target ) 






Id 


Rc , [RO] 






prot 


IKU J f Aiiasi 






id 


Rs, [R2] 






prot 


[R2] , Alias2 






Id 


Recx, [R7] 






prot 


[R7] , Alias3 






St 


tKs] , Rc, 


Sc 


add 


St 


(R2] ,Rs,NAC 


£c 


sub 


St 


IR7] ,Recx,NAC 


Sl 


andc 


selcc 


Reip, Rseq, Rtarg 


Sc 


is 


FA 


Aliasl 






FA 


Alias2 






FA 


AliasB 






j 


Sequential 







Rs , Rs , 4 & copy Reax , Recx 

Recx, Reax, 1 
:c Rll, Reax, Reax 
Epilog, Loop & commit 



Host Instruction key: 
NAC= No Alias Check 



The scheduled host instructions are illustrated in the sample above. It will be 
noted that the sequence is such that fewer clocks are required to execute the 
loop than to execute the primitive target instruction originally decoded from 
the source code. Thus, apart from all of the other acceleration accomplished, 
the total number of combined operations to be run is simply less than the 
operations necessary to execute the original target code. 
Store Elimination by use of the alias hardware. 
Entry: 

add RO,Rebp,Oxc 

add R2,Rebp,0x8 

add R7,Rebp,0xl0 

add Rseq, Reip, Length (block) 

Idc Rtarg, EIP (target) 

Id Rc, [RO] 

prot [RO] , Aliasl /protect the address from loads and 

stores 
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stores 

stores 
Loop: 

Epilog : 



Id 

prot 
Id 

prot 



Rs, [R2] 
tR2] ,Alias2 



Recx, [R7] 
[R7] ,Alias3 



St [Rs],Rc, 
sub Recx,Reax,l 
selcc Reip, Rseq, Rtarg 



FA 
FA 
FA 
St 
St 
j 



Aliasl 
Alias2 
Alias3 
[R2] ,Rs 
lR7j ,Recx 
Sequential 



; protect the address from loads and 



/protect the address from loads and 



& add Rs,Rs,4 & copy Reax,Recx 

& andcc Rll , Reax, Reax 

& jg Epilog, Loop U commit 



; writeback the final value of Rs 
; writeback the final value of Recx 



The final optimization shown in this sample is the use of the alias hardware to 
eliminate stores. This eliminates the stores from within the loop body, and 
performs them only in the loop epilog. This reduces the number of host 
instructions within the loop body to three compared to the original ten target 
instructions. 

Although the present invention has been described in terms of a preferred 
embodiment, it will be appreciated that various modifications and alterations 
might be made by those skilled in the art without departing from the spirit and 
scope of the invention. For example, although the invention has been 
described with relation to the emulation of X86 processors, it should be 
understood that the invention applies just as well to programs designed for 
other processor architectures, and programs that execute on virtual machines, 
such as P code, Postscript, or Java programs. The invention should therefore 
be measured in terms of the claims which follow. 



What Is Claimed Is: 
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1 Claim 1 . A buffer for controlling the storage in memoiy of data generated 

2 during execution of a sequence of instructions by a processor comprising: 

3 a plurality of storage locations each capable of holding data addressed to 

4 memory and the address of the data, 

5 means for transferring data generated by the operation of a processor to the 

6 storage locations as the data is generated until the sequence of instructions 

7 completes executing, 

8 means for identifying data in the buffer generated by a sequence of 

9 instructions which has not completed executing, 

10 means for detecting which is most recent data in the buffer directed to a 

11 particular memory address in response to a memory access, 

12 means for transferring data in the storage locations to memory after a 

13 sequence of instructions generating the stores has executed without generating 

14 an exception or an error, and 

15 means for eliminating memory stores in the storage locations when execution 

16 of a sequence of instructions generating the stores generates an exception or 

17 an error. 

1 Claim 2. A buffer as claimed in Claim 1 in which the means for detecting 

2 which is most recent data in the buffer directed to a particular memory 

3 address in response to a memory access comprises means for indicating each 

4 most- recent addressable amount of data in the buffer addressed to a particular 

5 memory address. 

1 Claim 3. A buffer as claimed in Claim 2 in which the means for identifying 

2 data in the buffer generated by a sequence of instructions which has not 
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3 completed executing comprises means for separating the data generated by a 

4 sequence of instructions which has not completed executing from other data in 

5 the buffer until the sequence of instructions has executed. 

1 Claim 4. A buffer as claimed in Claim 3 in which the means for separating 

2 the data from other data in the buffer until the sequence of instructions has 

3 executed is means for indicating a beginning and an end of a sequence of data 

4 in the buffer. 

1 Claim 5. A buffer as claimed in Claim 4 in which the means for indicating 

2 each most-recent addressable amount of data in the buffer addressed to a 

3 particular memory address in response to a memory access comprises means 

4 for replacing old data in a storage location between the beginning and the end 

5 of a sequence of data in the buffer with new data addressed to an identical 

6 memory address and being generated by the sequence of instructions not yet 

7 executed. 

1 Claim 6. A buffer as claimed in Claim 4 in which the means for indicating 

2 each most-recent addressable amount of data in the buffer addressed to a 

3 particular memory address in response to a memory access comprises: 

4 a first indicator for addressable storage locations to identify data being placed 

5 in the buffer as most-recent, 

6 a comparator comparing memory address of data being placed in a storage 

7 location and the memory addresses of data already in storage locations and 

8 removing the indicator for data having a memory address identical to the 

9 memory address of the data being placed in the storage location, 

10 a second indicator for addressable storage locations to identify data in the 

11 storage location as most-recent data generated by a sequence of instructions in 
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12 response to the execution of the sequence of instructions without an error or 

13 exception; and 

14 a comparator comparing memory addresses of data being eliminated from the 

15 buffer when execution of a sequence of instructions generating the stores 

16 generates an exception or an error and memory addresses of data to identify 

17 data not being eliminated and identified by a second indicator as most-recent 

18 data generated by a sequence of instructions in response to the execution of 

19 the sequence of instructions without an error or exception and writing a first 

20 indicator as most recent. 

1 Claim 7. A buffer as claimed in Claim 2 in which the means for eliminating 

2 data in the storage locations when execution of a sequence of instructions 

3 generating the stores generates an exception or an error comprises an 

4 indicator for invalidating the data in response to an error or exception 

5 generated in executing the sequence of instructions. 

1 Claim 8. A buffer as claimed in Claim 3 in which the means for separating 

2 the data from other data in the buffer until the sequence of instructions is 

3 executed comprises means for placing a sequence of data in a physically- 

4 separate portion of the buffer indicated to contain data from a sequence of 

5 instructions not yet executed. 

1 Claim 9. A buffer as claimed in Claim 8 in which the means for indicating 

2 each most-recent addressable amount of data in the buffer addressed to a 

3 particular memory address in response to a memory access comprises: 

4 means for replacing old data in a storage location in a physically- separate 

5 portion of the buffer indicated to contain data from a sequence of instructions 

6 not yet executed with new data addressed to an identical memory address and 

7 being generated by the sequence of instructions not yet executed. 
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1 Claim 10. A buffer as claimed in Claim 8 in which the means for transferring 

2 data in the storage locations to memory when a sequence of instructions 

3 generating the data has executed without generating an exception or an error 

4 further comprises means for indicating the data was generated by a sequence 

5 of instructions which executed without an error. 

1 Claim 11. A buffer as claimed in Claim 8 in which the means for transferring 

2 data in the storage locations to memory after a sequence of instructions 

3 generating the stores has executed without generating an exception or an error 

4 comprises a comparator for comparing memory addresses of data in the buffer 

5 generated by sequences of instructions which have executed without error or 

6 exception and selecting only the most-recent addressable data for storage at 

7 any memory address. 

1 Claim 12. A method of controlling the storing in memory of data generated by 

2 execution of a sequence of instructions by a processor comprising: 

3 transferring in sequence data associated with memory addresses as the data is 

4 generated to a segregated portion of a store buffer, 

5 detecting most recent data with a particular memory address in the store 

6 buffer in response to an access of the memory address, 

7 transferring all of the data from the segregated portion of the store buffer for 

8 draining to memory if the sequence of instructions does not cause an 

9 exception or error, and 

10 eliminating all of the data from the segregated portion of the store buffer if the 

1 1 sequence of instructions causes an exception or error. 

1 Claim 13. A method as claimed in Claim 12 in which the step of transferring 

2 data in sequence associated with memory addresses as the data is generated 
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3 to a segregated portion of a store buffer comprises the steps of placing the data 

4 in sequential storage locations in a portion of the store buffer between first and 

5 last storage location indications. 

1 Claim 14. A method as claimed in Claim 13: 

2 in which the step of transferring all of the data from the segregated portion of 

3 the store buffer for draining to memor>' if the sequence of instructions does not 

4 cause an exception or error comprises the step of moving the first storage 

5 location indication to designate the last storage location, and 

6 in which the step of eliminating all of the data from the segregated portion of 

7 the store buffer if the sequence of instructions causes an exception or error 

8 comprises the step of moving the last storage location indication to designate 

9 the first storage location. 

1 Claim 15. A method as claimed in Claim 14 in which the step of detecting 

2 most recent data with a particular memory address in the store buffer in 

3 response to an access of the memory address comprises the steps of: 

4 placing a first indication with any addressable data when placed in a storage 

5 location that the data is most recent data for a memory address associated 

6 with the data, 

7 placing a second indication with any addressable data when the data is 

8 transferred from the segregated portion of the store buffer that the data is the 

9 most recent transferred from the segregated portion of the store buffer, 

10 placing a first indication with any addressable data having a second indication 

1 1 when eliminating all of the data in the segregated portion of the store buffer, 

12 and 
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13 comparing the memory address and first indication of any data held in an 

14 addressable storage location in response to an access of a memory address of 

15 data held in the storage buffer. 

1 Claim 16. A method as claimed in Claim 12 in which the steps of: 

2 transferring data in sequence associated with memory addresses as the data is 

3 generated to a segregated portion of a store buffer comprises the steps of 

4 placing a sequence of data in a physically-separate portion of the buffer, and 

5 indicating that the physically segregated portion of the store buffer contains 

6 data from a sequence of instructions which has not completed executing. 

1 Claim 17. A method as claimed in Claim 16 in which the step of detecting 

2 most recent data with a particular memory address in the store buffer in 

3 response to an access of the memory address comprises the steps of: 

4 writing each separately addressable portion of data to the segregated portion of 

5 the store buffer over data addressed to the same memory address in the 

6 segregated portion of the store buffer, and 

7 comparing memory addresses of all data in the store buffer with any memory 

8 address being accessed to detect the most recent data in the store buffer. 

1 Claim 18. A method as claimed in Claim 16: 

2 in which the step of transferring all of the data from the segregated portion of 

3 the store buffer for draining to memory if the sequence of instructions does not 

4 cause an exception or error comprises the step of indicating that the physically 

5 segregated portion of the store buffer contains data from a sequence of 

6 instructions which has been executed, and 
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7 in which the step of eliminating all of the data from the segregated portion of 

8 the store buffer if the sequence of instructions causes an exception or error 

9 comprises the step of indicating that the physically segregated portion of the 

10 store buffer contains data which is invalid. 

1 Claim 19. A method as claimed in Claim 18 further comprising a step of 

2 draining to memory all of the data transferred from the segregated portion of 

3 the store buffer by comparing addresses of all data transferred from the 

4 segregated portion for each memory address and draining to memory only data 

5 which is most recent for any memory address. 

1 Claim 20. Apparatus for use in a processing system having a host processor 

2 capable of executing a first instruction set to assist in running instructions of 

3 a different instruction set which is translated to the first instruction set by the 

4 host processor comprising: 

5 a buffer including a segregated region for temporarily storing memory stores 

6 generated until a determination that a sequence of translated instructions will 

7 execute without exception or error on the host processor, 

8 logic circuitry for detecting the most recent memory store to a particular 

9 memory address held in the buffer in response to an access of the memory 

10 address, 

1 1 draining circuitry for removing memory stores temporarily stored from the 

12 segregated portion and permanently storing the memory stores when a 

13 determination is made that a sequence of translated instructions will execute 

14 without exception or error on the host processor, and 

15 means for eliminating memory stores temporarily stored in the segregated 

16 portion of the buffer when a determination is made that a sequence of 
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17 translated instructions will generate an exception or error on the host 

18 processor, 

1 Claim 21 . Apparatus for use in a processing system as claimed in Claim 20 

2 in which: 

3 the segregated region of the buffer is defined by pointers to first and last 

4 storage locations; 

5 the logic circuitry for detecting the most recent memory store to a particular 

6 memory address held in the buffer in response to an access of the memory 

7 address comprises 



8 a first position in each storage location for indicating most-recent 

9 memory stores, 

10 circuitry for placing an indication in a first position whenever a memory 

1 1 store is placed in a storage location and removing any indication in a 

12 first position for older memory stores to the same memory address, 

13 a second position in each storage location for indicating most- recent 

14 memory stores in other than the segregated portion of the buffer, 

15 circuitry for placing an indication in a second position whenever a 

16 memory store removed from the segregated portion by the draining 

17 circuitry and removing any indication in a second position for older 

18 memory stores to the same memory address, and 

19 a comparator for comparing memory addresses and detecting an 

20 indication in a first position for memory stores. 



1 Claim 22. Apparatus for use in a processing system as claimed in Claim 20 

2 in which: 
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3 the segregated region of the buffer is defined by a physically separated portion 

4 of storage locations having an indication that memory stores in the portion 

5 have been generated by a sequence of instructions which has not completed 

6 executing; 

7 the logic circuitry for detecting the most recent memory store to a particular 

8 memory address held in the buffer in response to an access of the memory 

9 address comprises: 



10 a memory address detector for writing a memory store over any memory 

11 store already in the segregated portion, 

12 circuitry for designating the order in which memory stores were placed 

13 in any physically separated portion of the buffer, and 

14 a comparator for comparing memory addresses and detecting the oldest 

15 memory store at any storage location in a portion of the buffer. 



1 Claim 23. A gated store buffer comprising: 

2 means for temporarily holding apart from other memory stores all memory 

3 stores sequentially generated during a translation interval by a host processor 

4 translating a sequence of target instructions into host instructions, 

5 means for transferring memory stores sequentially generated during a 

6 translation interval to memory if the translation executes without generating 

7 an exception, 

8 means for indicating which memory stores to identical memory addresses are 

9 most recent in response to a memory access at the memory address, and 

10 means for eliminating memory stores sequentially generated during a 

1 1 translation interval if the translation executes without generating an exception. 
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1 Claim 24. A computer comprising: 

2 a host processor designed to execute instructions of a host instruction set; 

3 host software for translating instructions from a target instruction set to 

4 instructions of the host instruction set; 

5 memory; and 

6 a store buffer for holding data generated by the host software in translating 

7 sequences of target instructions on the host processor comprising: 



8 a plurality of storage locations each capable of holding data addressed to 

9 memory and the address of the data, 

10 means for transferring data generated by the operation of the host 

11 processor to the storage locations as the data is generated until a 

12 sequence of instructions completes executing , 

13 means for identifying data in the buffer generated by a sequence of 

14 instructions which has not completed executing, 



means for detecting which is most recent data in the buffer directed to a 
particular memory address in response to a memory access, 



17 means for transferring data in the storage locations to memory after a 

18 sequence of instructions generating the stores has executed without 

19 generating an exception or an error, and 

20 means for eliminating memory stores in the storage locations when 

21 execution of a sequence of instructions generating the stores generates 

22 an exception or an error. 



wo 98/28689 PCTAJS97/22768 

98 

1 Claim 25. A computer as claimed in Claim 24: 

2 in which die means for transferring data generated by the operation of a 

3 processor to the storage locations as the data is generated until the sequence 

4 of instructions completes executing comprises means for transferring data to 

5 sequential storage locations in the buffer, and 

6 in which the means for detecting which is most recent data in the buffer 

7 directed to a particular memory address in response to a memory access 

8 comprises means for indicating each most-recent addressable amount of data 

9 in the buffer addressed to a particular memory address. 

1 Claim 26. A computer as claimed in Claim 25 in which the means for 

2 identifying data in the buffer generated by a sequence of instructions which 

3 has not completed executing comprises means for separating the data from 

4 other data in the buffer until the sequence of instructions has executed. 

1 Claim 27. A computer as claimed in Claim 26 in which the means for 

2 separating the data from other data in the buffer until the sequence of 

3 instructions has executed is means for indicating a beginning and an end of a 

4 sequence of data in the buffer. 

1 Claim 28. A computer as claimed in Claim 27 in which the means for 

2 indicating each most-recent addressable amount of data in the buffer 

3 addressed to a particular memory address in response to a memory access 

4 comprises means for replacing old data in a storage location between the 

5 beginning and the end of a sequence of data in the buffer with new data 

6 addressed to an identical memory address and being generated by the 

7 sequence of instructions not yet executed. 
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1 Claim 29. A computer as claimed in Claim 27 in which the means for 

2 indicating each most-recent addressable amount of data in the buffer 

3 addressed to a particular memory address in response to a memory access 

4 comprises: 

5 a first indicator for addressable storage locations to identify data being placed 

6 in the buffer as most-recent, 

7 a comparator comparing memory address of data being placed in a storage 

8 location and the memory addresses of data already in storage locations and 

9 removing the indicator for data having a memory address identical to the 

10 memory address of the data being placed in the storage location, 

1 1 a second indicator for addressable storage locations to identify data in the 

12 storage location as most-recent data generated by a sequence of instructions in 

13 response to the execution of the sequence of instructions without an error or 

14 exception, and 

15 a comparator comparing memory addresses of data being eliminated from the 

16 buffer when execution of a sequence of instructions generating the stores 

17 generates an exception or an error and memory addresses of data to identify 

18 data not being eliminated and identified by a second indicator as most-recent 

19 data generated by a sequence of instructions in response to the execution of 

20 the sequence of instructions without an error or exception with a first indicator 

21 as most recent. 

1 Claim 30. A computer as claimed in Claim 24 in which the means for 

2 eliminating data in the buffer identified as generated by a sequence of 

3 instructions comprises an indicator for invalidating the data in response to an 

4 error or exception generated in executing the sequence of instructions. 
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1 Claim 31. A computer as claimed in Claim 26 in which the means for 

2 separating the data from other data in the buffer until the sequence of 

3 instructions completes executing comprises means for placing a sequence of 

4 data in a physically-separate portion of the buffer indicated to contain data 

5 from a sequence of instructions not yet executed. 

1 Claim 32. A computer as claimed in Claim 31 in which the means for 

2 indicating each most-recent addressable amount of data in the buffer 

3 addressed to a particular memory address in response to a memory access 

4 comprises: 

5 means for replacing old data in a storage location in a physically- separate 

6 portion of the buffer indicated to contain data from a sequence of instructions 

7 not yet executed with new data addressed to an identical memory address and 

8 being generated by the sequence of instructions not yet executed. 

1 Claim 33. A computer as claimed in Claim 31 in which the means for 

2 transferring data in the storage locations to memory when a sequence of 

3 instructions generating the data has executed without generating an exception 

4 or an error further comprises means for indicating the data was generated by a 

5 sequence of instructions which executed without an error. 

1 Claim 34, A computer as claimed in Claim 31 in which the means for 

2 transferring data in the storage locations to memory after a sequence of 

3 instructions generating the stores has executed without generating an 

4 exception or an error comprises a comparator for comparing memory 

5 addresses of data in the buffer generated by sequences of instructions which 

6 have executed without error or exception and selecting only the most-recent 

7 addressable data for storage at any memory address. 
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